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SOF T... 

Curso Práctico de Programación 



El mundo de la programación 
del ordenador personal en una obra 
práctica, completa, didáctica y actualizada 




UCHOS hogares cuentan ya con un 
nuevo huésped, Un invitado que llena 
los ratos de ocio llevando la 
espectacular/dad de los juegos de 
acción a la pantalla del televisor, colaborando 
en la gestión de la contabilidad doméstica, 
controlando los movimientos de fas cuentas 
banca rías, ayudando al estudiante de la casa, o 
sugiriendo el menú adecuado para la próxima 
semana. 

Cada día son más y más las oficinas que han 
sustituido los pesados libros contables, fas 
máquinas de escribir, e incluso las tradicionales 
calculadoras, por una nueva herramienta, 
versátil, inteligente y eficaz. 
No cabe duda, el protagonista de la década es, 
con todos los honores, el ordenador personal. 
En muy pocos años, estas útiles máquinas han 
saltado de los libros de ciencia ficción y de las 
fantasías del celuloide a la cotidianidad. 
Mucho se ha avanzado en su conocimiento. 
Palabras como bit, microprocesador, hardware o 
software han perdido una gran parte de su 
misterio e impenetrabilidad para muchas 
personas, Pero siguen quedando muchas 
preguntas sin respuesta para los que se han 
incorporado más recientemente al mundo de la 
informática; o preguntas con una respuesta sólo 
apuntada, no definitiva, clara y detallada, para 
los más versados. 



¿Qué es y para qué sirve un ordenador 
personal? 

¿Qué soluciones aporta un ordenador personal 
en el hogar, en el despacho de un abogado, en 
la consulta de un médico, en el estudio de un 
escritor, en un comercio, en la empresa.. ? 
¿Qué datos hay que sopesar para adquirir el 
ordenador personal adecuado para cada 
situación y necesidad? 
¿Cómo obtener el máximo rendimiento del 
ordenador personal, conociendo sus 
posibilidades y limitaciones? 
¿Sabe cómo «instruir» al ordenador personal 
para que actúe de acuerdo a sus necesidades 
específicas? 

¿Qué tareas puede programar y cómo hacerlo? 





Curso Práctico de Programación 



SOFTWARE nace para dar una respuesta 
práctica a las cuestiones planteadas y 
a otros muchos interrogantes que 
convergen en el protagonista de la 
nueva era microinformática, 
E( ordenador personal es una 
máquina dispuesta a prestar una 
colaboración inapreciable, capaz de 
resolver una ingente variedad de 
aplicaciones. 

En su esencia más íntima, el 
ordenador personal no difiere mucho 
de otros dispositivos e instrumentos 
electrónicos destinados a una función 
específica. La transformación del 
conglomerado de circuitos 
electrón icos en máquina inteligente, 
en ordenador, obedece aun concepto 
mágico: la programación. 
Para convertir a la máquina 
programable en un útiJ colaborador, 
es preciso conocerla, saber cómo 
rodeada de fos periféricos 
adecuados para cada necesidad y, 
desde fuego, aprender a instruirla 
para que realice con eficacia y 
premura las tareas más dispares. 
En definitiva, la actuación del 
ordenador depende por completo de 
la programación que reciba. Por lo 
tanto, hay que aprender a dialogar 
con la máquina; dominar su lenguaje, 
conocer los sistemas operativos que 
constituyen su inteligencia elemental 
y rigen su funcionamiento, y 
familiarizarse con los programas y 
paquetes de aplicación estandarizados 
que convierten al ordenador personal 
en un eficiente colaborador, 
Tres son los eslabones que dan 
cuerpo al concepto de programación: 
los sistemas operativos, los lenguajes 
de programación y el software da 
aplicación. Su coexistencia en la 
máquina convierte a ésta en un 
ordenador, capaz de acometer y llevar 
a buen término las más diversas 
tareas. 





II 



¿QUE ES Y PARA QUE SIRVE 

En su definición más simple, el orde- 
nador personal no es más que una 
máquina, de reducidas dimensiones 
y precio moderado, cuyo cerebro 
está regido por un circuito integrado 
programable: el microprocesador. 
Tal definición es extensiva a la gene- 
ralidad de equipos destinados al tra- 
tamiento de información, cuya uni- 
dad central de proceso está organi- 
zada en torno a un microprocesa- 
dor: los microordenadores. Dentro 
de esta gran familia, caben potentes 
equipos para la gestión de tareas 
■ complejas y sofisticadas, y microor- 



EL ORDENADOR PERSONAL? 



denadores capacitados para distri- 
buir su atención entre varios usua- 
rios simultáneamente. Y, por su- 
puesto, toda la enorme variedad de 
ordenadores personales. 
La distinción entre el ordenador per- 
sonal y tos restantes microordena- 
dores, cabe precisarla en su obje- 
tivo: equipos destinados al trata- 
miento de información gobernados 
por un usuario individual. Una ca- 
racterística que afecta a su ámbito 
de explotación, individualizado, no 
multiusuario. Hay ordenadores per- 
sonales especialistas en 3a vertiente 



más lúdica (juegos de acción, de re- 
flexión, de estrategia...); inclinados 
a la enseñanza asistida por ordena- 
dor; versados en la confección del 
correo personal y el control de las 
cuentas domésticas; verdaderos ex- 
pertos en la gestión de archivos y en 
el tratamiento de datos; virtuosos 
en el arte de automatizar el hogar; 
consumados expertos en la planifi- 
cación de supuestos financieros; efi- 
caces y potentes gestores de las ta- 
reas de administración en el ámbito 
de una pequeña o mediana empresa... 



™» Curso Práctico de Programación 



Una obra completa y actualizada, organizada en cuatro secciones 

que recogen todo el mundo de la programación del ordenador personal. 




Basic 



Curso práctico de lenguaje BASIC, particularizado para ios ordenadores personales 
más populares. Con un tratamiento gráfico, didáctico y repleto de programas 
y ejemplos. 




Lenguajes 



Un estudio completo y detallado de los principales lenguajes para ordenadores 
personales. 




Sistemas Operativos 



La inteligencia elemental del ordenador al descubierto, con un pormenorizado análi- 
sis práctico de los sistemas operativos que predominan en el campo de los ordenado- 
res personales. 




Aplicaciones 



Una guia practica para elegir y aprender a utilizar los programas y paquetes de 
aplicación que convierten al ordenador personal en un colaborador eficiente 
y versátil. 



Todo ello completado con una amplia variedad de cuadros, complementos 
e ilustraciones que familiarizarán al lector con los conceptos básicos 
de la informática del ordenador personal. 

IV 




El ordenador personal. Todo un símbolo 
de la sociedad moderna nacido de la feliz 
Idea que asaltó a Jonathan Titus, en 1974: 
utilizar un circuito integrado de la firma 
americana Intel — cuya referencia era Intel 
8008 y al que denominaban 
microprocesador—, para crear un pequeño 
ordenador destinado a los aficionados al 
brícolage electrónico... Ocho años 
bastaron para que en 1982 la prestigiosa 
revista TIME nombrara «Personaje del 
año» al ordenador personal. 
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Curso Práctico de Programación 



CURSO DE BASIC 

Si hubiera que destacar un lenguaje 
dentro del universo de los ordena- 
dores personales, éste sería, sín lu- 
gar a dudas, el BASIC. Un lenguaje 
popular y compartido por casi la to- 
talidad de los equipos presentes en 
el mercado. 

El desarrollo del CURSO DE BASIC 
incluye un estudio completo y deta- 
llado, repleto de ejemplos, del voca- 
bulario y la sintaxis del lenguaje BA- 
SIC; dedicando una constante atem 
ción a fos dialectos que constituyen 
el idioma de los ordenadores perso- 
nales de mayor difusión y popula- 
ridad. 

Paralelamente, se describen las téc- 
nicas y métodos de programación 
que permitirán al lector confeccio- 
nar sus propios programas, cada vez 
más complejos y potentes, adecua- 
dos para resolver múltiples aplica- 
ciones. 

A lo largo del curso, el lector encon- 
trará un dilatado abanico de progra- 
mas de juegos, educativos, de ges- 
tión y utilidades que guiarán su 
aprendizaje a través de la práctica. 

Los dialectos considerados dentro 
del CURSO DE BASIC, corresponden 
a ordenadores tan populares como 
ZX-SPECTRUM, ZX-S1, COMMODO- 
RE-64, VIC-20, DRAGON, ATAfll 
SPECTRAVÍDEO, ÜRIC, NEWBRAIN 
SHARP, AMSTRAD, Equipos MSX, 
BM-PC, APPLE, DIGITAL, OLIVETTI, 
TOSHIBA, NCR... 




f v i i i i t i i 





LENGUAJES 

A la hora de establecer un diálogo 
con el ordenador, el usuario no sólo 
cuenta con el lenguaje BASIC. Hay 
ztros lenguajes informáticos, asen- 
tados en el mundo del ordenador 
□ersonaí, que coexisten con el BA- 
53C y que incluso superan a éste úl- 
timo en determinadas áreas: ense- 
ñanza, juegos, tareas científicas, de 
gestión _ 

lernas de aportar los conocímien- 
básícos relativos al mundo de 
lenguajes, esta sección abordará 
eá estudio práctico de los lenguajes 
™ ás importantes en el ámbito del 
ordenador personal. Entre ellos 
cabe destacar los siguientes: 

— LOGO 

— PASCAL 

— FORTRAN 

— COBOL 

— FORTH 
«C» 

- ADA 
USP 

— APL 

— PILOT 



SISTEMAS OPERATIVOS 

Los cimientos del edificio de la pro- 
gramación los aporta la circuitería, 
el hardware de! ordenador personal. 
Sobre esta base, hay que empezar 
colocando la estructura que acogerá 
a los traductores de lenguajes y a los 
programas y paquetes de aplica- 
ción. 

La estructura que soportará a los 
restantes elementos de la progra- 
mación no es más que el sistema 
operativo, Una inteligencia elemen- 
tal que da píe al desarrollo del orde- 
nador, y que condiciona su expan- 
sión en el terreno de la programa- 
ción. Tanto los traductores de len- 
guajes como los paquetes de aplica- 
ción entran al sistema a través de la 
vía de compatibilidad que abre el 
sistema operativo, 
Son muchos los sistemas.operatívos 
concebidos para regir la actividad 
del ordenador personal Entre ellos 
cabe destacar un grupo que ostenta 
el liderazgo casi absoluto y que reci- 
ben, dentro de esta sección, un tra- 
tamiento detallado y didáctico: 

— CP/M y toda su familia de deriva- 
dos {CP/M-80, CP/M-86, MP/IVL..) 

— MS/DOS (PC/DOS, MSX/DOS, 
XENIX) 

— APPLE DOS 

— PRO. DOS 

— OASIS 

— PICK 

— UNIX 

— UCSD 

— FLEX 




APLICACIONES 

Nada más frecuente que la imagen 
del ordenador resolviendo un com- 
plicado análisis financiero, confec- 
cionando la nómina de la empresa, 
colaborando en el proceso de tex- 
tos, gestionando una completa y de- 
tallada base de datos, o aportando 
su inteligencia al tiempo de ocio con 
emocionantes juegos. 
A la hora de proveer al ordenador de 
los programas adecuados para cada 
aplicación, el usuario dispone de va- 
rias alternativas: confeccionar sus 
propios programas, encargar su 
confección «a medida», o adquirir 
programas estandarizados que pue- 
dan resolver sus necesidades espe- 
cíficas. 

Los grupos más importantes de pro- 
gramas y paquetes de aplicación tie- 
nen un lugar en SOFTWARE. Un estu- 
dio completo y detallado que se com- 
pleta con el análisis práctico de los 
principales paquetes destinados a 
aolicaciones de gestión: 

— Tratamientos de textos. 

— Hojas electrónicas. 

— Sistemas para la gestión de ba- 
ses de datos, 

— - Software gráfico. 

— Generadores de programas. 

— Paquetes para comunicaciones. 

— Gestionadores de tiempo y ta- 
reas, 

— Paquetes integrados. 
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CURSO DE BASIC 



LENGUAJES /SISTEMAS OPERATIVOS 
SOFTWARE DE APLICACION 



Curso práctico de programación 
del ordenador personal 

Una obra indispensable para vivir ef 
presente y no perder pie en la sociedad 
del futuro. 

52 fascículos encuadernabas en cuatro 
tomos. 

1048 páginas a todo color, con más de 
3.000 fotografías e ilustraciones. 

Una auténtica biblioteca práctica de la 
informática del ordenador personal, 
imprescindible como obra de consulta 
V aprendizaje. 
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Basic 



El ordenador personal 

El símbolo de la nueva sociedad 
informática 




lo largo de su historia, la huma- 
nidad ha asistido a grandes re- 
voluciones. Revoluciones de- 
sencadenadas, en muchos ca- 
ses, por innovaciones tecnológicas. Algu- 
mes llegaron a influir tan drásticamente en 
- desarrollo de fa sociedad, que abrieron 
_ra nueva era en la historia. 
_ " de los principales condicionantes de 
3 evolución humana son los métodos de 
Erajo de sus protagonistas; y estos mé- 
■ ::3 se ven alterados por ciertos deste- 
" e el ámbito de la tecnología. No hay 
^nas que pensar en el efecto que tuvieron, 
ai sus respectivas sociedades, la inven- 
ten del fuego, la rueda o el arte de traba- 
s hierro. 

i' r siglo XVIII se encuentra el penúltimo 
i". - eslabón de la cadena de revoluciones 
filológicas: la revolución industrial. La 
□roducción artesa nal había agotado todas 
. ; posibilidades; los productos escasea- 
Sen y alcanzaban precios desorbitados. 
E*a necesario crear máquinas capaces de 
alentar las posibilidades de producción. 
-JDS nuevos métodos de producción con- 
exionaron la economía mundial. Los paí- 
ses que no supieron o no pudieron estar.al 
: _ L quedaron apeados durante mucho 
tiempo, y en algunos casos de forma casi 
reversible, del camino hacia la sociedad 
actual. 



_A REVOLUCION INFORMATICA 



-nales del siglo XIX y principios del XX, 
:ezc a observarse un estancamiento 
ei terreno de la administración. Empre- 
s ze envergadura encontraban dif iculta- 
^ oara tratar y archivar el flujo de infor- 




Con la entrada en escena del microprocesador, los ordenadores han reducido su tamaño y 
precio. En la actualidad su presencia es habitual en cualquier ambiente: oficinas, despachos 
profesionales, e incluso en el hogar. 




Los primeros ordenadores fueron mecánicos. Más tarde, en un primer salto tecnológico, 
pasaron a estar constituidos por válvulas, luego por transistores y, en la actualidad, por 
c in uitos in tegra dos . 
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mación que las asaltaba. Paralelamente, 
algunas disciplinas del saber científico 
empezaron a quedar vedadas a un mayor 
conocimiento, dada la imposibilidad de 
acometer los voluminosos cálculos que 
exigían. 

La mente humana empezó a buscar solu- 
ciones: las máquinas no sólo debían ma- 
nufacturar objetos, sino también informa- 
ción. 

Ya en el siglo XVII [se habían esbozado 
algunas ideas tendentes af tratamiento 
automático de la información. Se pensó 
en la posibilidad de crearartilugios mecá- 
nicos capaces de realizar este cometido. 
Aunque era posible concebirlos en el 
plano teórico, pronto se comprobó que 
existían un puñado de buenas razones 
que hacían rnvíable el desarrollo de estas 
máquinas. 

Estrenado el siglo XX, surgió la idea de 
utilizar dispositivos electromecánicos. Es- 
tos no dieron mal resultado; sin embargo, 
tenían muchas limitaciones. Era preciso 
dar un nuevo salto. Este se consumó al 
descubrir los primeros dispositivos elec- 
trónicos, que relegaron al olvido la idea del 
ordenador mecánico. 
En una fecha reciente, a mediados de 
este siglo, los descubrimientos en el 
campo de la electrónica permitieron el na- 
cimiento de los primeros ordenadores 
modernos. Empezaron a construirse a 
partir de válvulas de vacío. Más tarde con 



transistores Y r por último, a base de cir- 
cuitos integrados. Los primeros ordena- 
dores eran voluminosos cajones llenos de 
parafernalia electrónica, destinados, prin- 
cipalmente, a aplicaciones científicas y 
militares. Mas tarde, fueron reduciendo 
su tamaño y precio. Hasta llegar a la ac- 
tualidad: con la irrupción del microproce- 
sador (su cerebro integrado), ios ordena- 
dores han sorteado totalmente la barrera 
de volumen y precio, llegando a ser ase- 
quibles al gran público. 
Hoy en día, un ordenador está al alcance 
de cualquier bolsillo; ha franqueado el 
umbral del hogar. Y tal vez, muy pronto, 
se convierta en un electrodoméstico tan 
imprescindible como puede serlo el tele- 
visor o la lavadora automática. 



¿QUE ES UN ORDENADOR? 



Un ordenador es una máquina programa- 
ble cuyo cometido es ef tratamiento auto- 
mático de la información. Una actividad 
genérica que se sintetiza en tres fases: 
entrada de la información, tratamiento o 
procesado de la misma, y salida de la in- 
formación resultante del tratamiento. 



Para acometer esta tarea genérica, el or- 
denador cuenta en su interior con disposi- 
tivos electrónicos capaces de transformar 
la información en señales eléctricas (en- 
trada). Su propia circuitería electrónica 
manipulará las señales eléctricas de 
acuerdo a las instrucciones recibidas (tra- 
tamiento de ¡a información). Y r por último, 
las señales eléctricas resultantes serán 
convertidas, por obra y gracia de los dis- 
positivos electrónicos, en una información 
inteligible (salida). 

La celeridad con la que actúan los disposi- 
tivos electrónicos, permiten al ordenador 
realizar múltiples operaciones en unas po- 
cas fracciones de segundo. Ello convierte 
al ordenador en una herramienta rápida y 
eficiente en un sinfín de actividades rela- 
cionadas, todas ellas, con el tratamiento 
de Ja información. Por ejemplo, puede cla- 
sificar y archivar grandes lotes de informa- 
ción, con rapidez y fiabiJidad. Es capaz de 
trabajar con datos numéricos, operando 
densos y complicados cálculos. Y también 
resulta eficaz en las actividades de control 
de procesos: puede tratar la información 
procedente de un conjunto de sensores y 
controlar a otros instrumentos asociados 
al ordenador. 

Algunos representantes de esta gran fa- 
milia de máquinas programadles, los orde- 
nadores personales, han saltado ya a los 
escaparates de las tiendas de electrodo- 
mésticos. 



TOMA DE CONTACTO 
CON EL ORDENADOR 



Mucho es lo que queda por añadir acerca 
de la naturaleza y posibilidades del orde- 
nador; todo un compendio de conoci- 
mientos que se irán exponiendo e ilus- 
trando a lo largo de esta obra. Por el mo- 
mento, es suficiente con una somera idea 
inicial. Quien debe presentarse ahora es el 
propio ordenador, tal y como se nos revela 
al abrir la sugerente caja que nos entregan 
en la tienda. 

La adquisición de un pequeño ordenador 
personal suele ser, para muchos, el pri- 
mer paso en el sendero de la informática, 
y la solemne apertura de la caja, su primer 
contacto con la realidad del ordenador. 




La revolución m icroinform ática ha puesto al arde na doy personal ai ahume del gran público. 
Tal vez se convierta, muy pronto, en un útil tan imprescindible como ana calculadora o una 
máquina de escribir. 
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. " r vez desempaquetado, nos encontra- 
dos con 'un pequeño y liviano mueble de 
: estico, repleto de teclas y tomas de co- 
■ - on: un ordenador, ni más ni menos, 
z~ si fondo de la caja tropezamos con su 
::^e de acompañantes: 1 ' una pequeña 
= pesada y compacta, de la que parten 
rabies, un manual y otros dos mazos 

- :able con sus respectivos conectores 
ir cada extremo. En definitiva, todo lo 
'ecasario para que nuestro flamante or- 
denador pueda demostrar sus habili- 
tes. 

. :esada caja flanqueada por sendos ca- 
aes, no es más que el alimentados a tra- 
bes del cual el ordenador recibirá la ener- 
: = :omada de la tensión de la red eléc- 
El extremo de uno de los cables se 
rr^ectará a la toma que el ordenador po- 
see al efecto, mientras que el otro ex- 
Tsmo se insertará en un enchufe de la red 
pgetríca. 

. : •:• a os cables que viajan separados son, 
-^soectivamente, para la conexión de una 
tcantalla» (el órgano de visualización) y 

- ■= la adaptación al ordenador de un dis- 
: : sítivo de memoria externa. En la mayor 

de los ordenadores, la pantalla de 
1 -3Üzación puede ser un simple televi- 
sor doméstico, Uno de los extremos del 
-Z e al efecto se conectará a la entrada 
jé antena del receptor de TV y el otro al 
llenador. 

" : " el ordenador conectado a la tensión 
z~ red, a través del alimentados y aso 
--zd al receptor de TV, ya se puede em- 
. ziar a trabajar. No obstante, si se desea 
: : "juntar un sistema realmente operativo, 
^acen falta aún otros complementos. 
Para almacenar la información en un so- 
is permanente y no tener que reescri- 
: ■ 5 cada vez que se enciende el ordena- 
Do r , es preciso contar con un periférico de 
i —acenamiento: un dispositivo capaz de 
yabar, memorizar y reproducir informa- 
zórt. Este puede ser un simple magnetó- 
■ " - : a casetes o una unidad para discos 
^exibles. En un ordenador doméstico, la 
mativa inicial suefe coincidir con el 
magnetófono a casetes Y ahí está el co- 
xetido del cable que permanecía en la 
= ¡unto con el manual; un extremo se 
:: _ ectará al magnetófono y el otro al or- 

~ Dtro componente básico de un sistema 
enador.se rá un periférico que nos per- 

- "= obtener una- copia de la información, 
- i3l forma que podamos verla sin nece- 

sCad de mantener encendido ef aparato. 
z- efecto, nos referimos a la impresora: 



un dispositivo externo capaz de obtener 
copias en papel de la información conte- 
nida en el ordenador. 
Al observarla zona posterior y los laterales 
del mueble del ordenador, se observa que 
aún quedan algunos conectores sin utili- 
zar. Un repaso al manual nos permitirá 
deducir cuát es e! cometido específico de 
cada uno de estos conectores de expan- 
sión. 



EL ORDENADOR Y SU ENTORNO 



La toma de contacto con el ordenador nos 
ha permitido esbozar una idea muy impor- 




/ Vamos a dialogar en BASIC con el ordenador* Para ello, habrá que empezar rodeándolo de 
ios complementos imprescindibles: un alimentados a través del que recibirá la energía 
necesaria, y aria pañí alia (monitor de vídeo o receptor de TV i en la que plasmar los mensajes. 



Una breve historia del BASIC 



El lenguaje de programación BAS3C 
(Beginner's All-Purpose Symbolic 
Instruction Code) nadó en 1964 en el 
Dartmouth College, de la mano de 
John G. Kemeny y Th ornas Kurtz, y fue 
concebido como un lenguaje interactivo, 
polivalente y de fácil aprendizaje 
y empieo. 

En un principio fue normalizado por el 
organismo ANSÍ (American National 
Standards Institute) y de esta 
normalización parten las lineas originales 
del BASIC. Más tarde, surgió toda una 
gran familia de dialectos que cada vez se 
fueron desviando más y más del 
lenguaje original. 

En 1977, la empresa americana Microsoft 
desarrolló un dialecto que pretendía 
unificar criterios, Rápidamente fue 
aceptado por varios fabricantes de 



ordenadores como Tandy, Apple r 
Commodore... 

El gran boom del BASIC ha llegado con la 
irrupción de los microordenadores, con la 
gran ventaja de su precio, que los ha 
hecho asequibles a cualquier bolsillo. Pero 
hay que señalar que en un principio el 
BASIC fue adoptado por los sistemas 
comerciales de tiempo compartido. De 
éstos es de donde viene la popularidad 
del BASIC. 

En la década de ios ochenta, el BASIC se 
ha constituido en el lenguaje de 
programación más utilizado. Aunque se 
habla de varios lenguajes como futuros 
sustitutos del BASIC, lo cierto es que 
ninguno amenaza seriamente la 
posición privilegiada que éste mantiene 
en el campo del ordenador personal. 
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La adquisición de un pequeño ordenador 
personal constituye, para muchas personas, 
su primer paso en el sendero de la 
informática. Un primer paso que conlleva la 
exigencia de familiarizarse con el lenguaje 
del ordenador: el BASIC sin lugar a dudas. 



tante. Para que éste se convierta en un 
instrumento plenamente utilizable, es 
preciso rodearlo de algunos periféricos o 
dispositivos externos: hay que construir 
un sistema ordenador. Como ya hemos 
observado, fos dispositivos periféricos 
son los que permiten al ordenador esta- 
blecer una comunicación con el usuario o 
universo exteriora la máquina. Estos pue- 
den dividirse en tres grandes bloques: pe- 
' ~e r :cos de entrada, periféricos de salida y 
unidades para el almacenamiento de in- 
formación. 

El periférico de entrada más común es el 
teclado; su importancia es tai que, nor- 
malmente, suele suministrarse junto con 
la unidad central del ordenador. Otros pe- 
riféricos de entrada, frecuentes en los or- 
denadores domésticos, son los mandos 
para juegos: joysticks (palancas de juego), 
paddles, lápices ópticos, tabletas gráfi- 
cas... 

Los periféricos de salida son los que tras- 
ladan al exterior fa información de salida o 
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Para que el ordenador se convierta en un instrumento con plena eficacia práctica, es preciso 
rodearlo de algunos periféricos o dispositivos externos. Los acompañan fes más frecuentes del 
ordenador personal son; el teclado, para comunicarte las órdenes y mensajes; la pantalla u 
órgano de visuaíización; las unidades para el almacenamiento de información (cinta de tipo 
cásete o discos flexibles); la impresora, para obtener copias en pape! de (a información 
procesada, y ios periféricos para juegos, entre tos que destaca el popular «jovstíck». 



respuestas del ordenador. Dentro de este 
grupo se encuentran las pantallas (ya sea 
un monitor de vídeo o un simple receptor 
de TV), las impresoras... 
Por úftimo, hay que hablar de las unidades 
para almacenamiento de información. Es- 
tos son periféricos que permiten af orde- 
nador conservar la información que pueda 
necesitar en cualquier otro momento. Su 
actuación se plasma en dos operaciones: 
escritura (grabación) y lectura (recupera- 
ción) de la información procedente o des- 
tinada al ordenador. Dentro de esta cate- 
goría destacan fas unidades de cásete y 
las unidades de disco flexible; aunque 
también cabe hablar de las unidades de 
disco rígido, de cinta magnética, etc. 
Además de los dispositivos periféricos, 
cabe mencionar a otros complementos o 
medios de expansión que tienen por ob- 
jeto potenciar las posibilidades del sis- 
tema ordenador. Estos útiles de expan- 
sión pueden ser circuitos electrónicos que 
incrementan la potencia de cálculo, am- 
plían la zona de memoria interna del orde- 
nador, o permiten la conexión al sistema 
de otros tipos de periféricos. Estos últi- 
mos medios de expansión, de adaptación 
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verface, compatibalizan el formato de 
□municación del ordenador con los dis- 
5 ;:vos periféricos. 



ESTRENANDO EL DIALOGO 



: i'denador está ya en disposición de 
mitrar en funcionamiento. Dada su activi- 



dad —entrada, tratamiento y salida de 
información — r es obvio que la atención 
del usuario debe empezar por centrarse 
en las dos «vías» a través de tas que se 
establecerá el diálogo. El camino de en- 
trada, para «hablar» con el ordenador, lo 
aporta el teclado; un medio que resultará 
familiar ya que, salvo la presencia de algu- 
nas teclas especiales, su semejanza es 
total con el de una máquina de escribir. 
Así, pues, para entablar una comunicación 
con el ordenador, habrá que «teclear» las 
palabras. La vía de salida de información 



no exige mayores detalles puesto que se 
trata de una simple pantalla. En ella apare- 
cerán las « respuestas » de la máquina. 
El alimentador está ya enchufado a la ten- 
sión de red; basta sólo con accionar el 
interruptor de encendido para dar vida a la 
máquina. Tras un ligero parpadeo de la 
pantalla, ésta visualiza un mensaje de pre- 
sentación, distinto según el modelo de 
ordenador. Bajo éste, aparece un ele- 
mento que a partir de ahora se convertirá 
en familiar: el cursor. 
El cursor es el nombre que recibe el sím- 



El teclado 



El periférico o dispositivo más frecuente a 
Través del que hablaremos con la máquina 
es el teclado. Tal como ocurre con las 
T:¿quinas de escribir, éste suele presentar 

ge ras diferencias según el modelo, si 
oien su estructura es muy parecida. 
El teclado de un ordenador incorpora una 
zona básica, cuyas teclas son muy 
semejantes a las de una máquina de 
escribir; esta zona es la que se denomina 

redado alfanumérico». En ella están 
¿grupadas las letras del alfabeto, las cifras 
racimales y algunos símbolos y 
caracteres ortográficos. 
_a diferencia respecto a la máquina de 
escribirse debe a la presencia de algunas 
Teclas especiales, útiles para comunicar al 
ordenador ciertas órdenes que 
condicionarán su actividad. 
A'gunos teclados de ordenadores pueden 
omitir la presencia de ciertas teclas 
especiales, incorporar otras, o alterar su 
nombre. No obstante, las más frecuentes 
son las que se relacionan en el 
gráfico adjunto, 

RETURN (ENTER en otros teclados): hay 
aue accionarla al terminar la introducción 
ze una orden o mensaje. Al pulsarla, el 
ordenador «asimilará» el mensaje 
introducido, 

CONTROL: cambia la función de algunas 
teclas con objeto de introducir una orden 
o mensaje de control. 

NSERT {Insertar): se utiliza para insertar 
- ..ovos caracteres en medio del texto 
anteriormente escrito. 

DELETE {Borrar) : hace retroceder el 
cursor una posición, borrando el carácter 
que la ocupaba. 

BREAK (Ruptura): rompe con la tarea que 
está ejecutando el ordenador, 



RESET (Inicialización): devuelve al 
ordenador a su estado inicial previo a 
cualquier actividad. 

CLEAR (Limpiar pantalla): borra el 
contenido de la pantalla. 

HOME: devuelve el cursor a la posición 
de origen. 



SHJFT (Desplazamiento): selecciona el 
carácter superior de cada tecla; en las 
teclas alfabéticas, selecciona las 
mayúsculas correspondientes. 

Desplazamiento del cursor: en el teclado 
existen cuatro teclas, cada una con la 
flecha en un sentido, que permiten mover 
el cursor en cualquier dirección. 



RETURN RETROCESO 



RESET INICIALIZACION 



CTRL 



1NS 



DEL 



CONTROL 
(Control) 



INSERTAR 
(Insert) 



BORRAR 
(Delete) 



CLEAR 



BORRADO 
DE PANTALLA 



RETORNO DEL 
CURSOR 
AL ORIGEN 



MOVIMIENTO 
DEL CURSOR 



BREAK RUPTURA 



SHIFT . DESPLAZAMIENTO 
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bolo situado en el margen izquierdo de la 
pantalla (un cuadrado o un srmpfe guión). 
Este es un elemento característico que 
señala la posición en la que se escribirá el 
próximo carácter que se lleve a la pantalla. 
Cualquier acción sopre una tecla tiene 
como consecuencia el desplazamiento del 
cursor en una posición a la derecha; su 
lugar lo irán ocupando las letras, cifras o 
símbolos que correspondan a las teclas 
pulsadas. 

A pesar de que comparten una estructura 
semejante, el teclado de cada modelo de 
ordenador presenta sus particularidades. 
La forma de cada tecla y su distribución 
conjunta difiere de un ordenador a otro 
Por lo demás, el número de teclas espe- 
cíales, distintas de Jas teclas alfabéticas y 
numéricas de una máquina de escribir, 
también varía según el equipo. 
También difieren los caracteres y los sím- 
bolos que se introducen al accionar una 
determinada tecla simultáneamente con 
la de selección de mayúsculas («SHIFT»). 
Otro tanto ocurre con las órdenes y fun- 
ciones seleccionadas al accionar una 
cierta tecla de caracteres junto con la tecla 
CONTROL («CTRL»). Estas diferencias no 
suponen un obstáculo que dificulte el diá- 
logo con el ordenador. La única distorsión 
es que obligan al usuario a consultar el 
manual de su equipo, para saber de qué 
funciones dispone el teclado y con qué 
combinación de teclas se seleccionan. 
Una vez que se conozca la forma de escri- 
bir caracteres en la pantalla, borrarlos, e 
insertar nuevos caracteres en cualquier 
posición, queda ya abierto ei camino del 
diálogo. Este empezará con la escritura de 
fas órdenes, instrucciones y mensajes 
que el usuario desee transmitir al ordena- 
dor; cada una de ellas, debe terminarla el 
usuario pulsando la teda RETURN; o la 
tecla ENTER, su homologa en determina- 
dos equipos. La acción sobre esta tecla 
indica al ordenador que debe «asimilar» el 
mensaje que la precede 
Es hora ya de estrenar el diálogo. 
Una tras otra hemos pulsado fas cuatro 
teclas y nuestro saludo aparece ya en la 
pantalla. Ahora hay que concluir la intro- 
ducción accionando la tecla RETURN, para 
que la máquina asimile nuestro mensaje: 
Aquí es donde se encuentra el verdadero 
obstáculo: la máquina no entiende el cas- 
tellano. Hemos introducido el mensaje, 
seguido de una acción sobre la tecla RE- 
TURN,., Sin errores. No obstante, la res- 
puesta de la máquina es un mensaje de 
error: "SYNTAX ERROR" (o un mensaje 
parecido según el modelo de ordenador). 




El ordenador, la fuente de alimentación, el manual de instrucciones y dos rabies para unir la 
maquina con un magnetófono a casetes y con un receptor de TV. Todo lo necesario para 
tomar el primer contado con la realidad del ordenador. 




m. m, m m m m m, m m * 
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La principal vía a través de la que se establece el diálogo con el ordenador es el teclado. Este 
es semejante al de una máquina de escribir convencional, aunque con algunas teclas 
adicionales adecuadas para comunicar ciertas órdenes a la maquina. 
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FORTRAN 
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ALGOL I 



BASIC I 




El BASIC es el lenguaje de programación más popular en rutes iros días. Sus rafees parren de 
mros dos lenguajes informáticos: el FORTRAN y el ALGOL, 



( ^ 

■ PINTA LAS LETRAS "AS C 



I 



1 RETURN 






l 1 



< >l 

PRINT "ABC" 



RETURN P 

jj 



Una mi conectado el ordenador, intentamos el primer diálogo. Con sorpresa observamos que 
m e<¡ capaz de entender nuestro idioma. En efecto, las máquinas programabíes tienen su 

>pio lenguaje -<>l BASIC es el primordial^, que el usuario debe aprender y utilizar para 
'.acer posible la comunicación con el ordenador. 



El ordenador no entiende el mensaje 
J 'HOLA" y nos advierte que hemos come- 
tido un error. En vista de los mensajes que 
muestra la pantalla, cabría suponer que su 
idioma es el inglés. Podemos intentarlo 
de nuevo introduciendo el mensaje tradu- 
cido ("HELLO"). La respuesta sería idén- 
tica: "SYNTAX ERROR". 
En efecto, el ordenador no entiende nin- 
gún idioma «humano». Sólo es capaz de 
entender los mensajes escritos en deter- 
minados lenguajes especiales, los deno- 
minados lenguajes de programación. Ade- 
más, su capacidad para dialogar en base a 
los lenguajes de programación no es ge- 
neral: sólo está capacitado para asimilar 
los mensajes formulados en un solo len- 
guaje de programación, aquel para el que 
se haya educado a la máquina. 
Usted, por ejemplo, entiende perfecta- 
mente el castellano (su lengua materna), 
pero es capaz, bajo ciertas circunstancias 
(estudiando, viajando...), de entender in- 
glés, francés. El ordenador personal 
tiene también su «lenguaje materno», 
que es el que se adjunta con el equipo; e 
incluso está capacitado para «aprender» 
otros lenguajes, en determinadas condi- 
ciones. 

La conclusión es obvia: para establecer 
cualquier diálogo con el ordenador es ne- 
cesario aprender su lenguaje de progra- 
mación. 



EL LENGUAJE BASIC 



El lenguaje de programación más común 
en el campo de los ordenadores persona- 
les es el BASIC. Su nombre está cons- 
truido a partir de las iniciales de Begin- 
ner's Ail-Purpose Symboiic ínstruction 
Code: Código de instrucciones simbólicas 
de uso general para principiantes. Toda 
una definición del objetivo que motivó la 
creación de este popular lenguaje. 
A la hora de desarrollar un lenguaje de 
programación polivalente y de fácil uso 
por los programadores noveles, los crea- 
dores del BASIC se inspiraron en dos len- 
guajes de alto nivel muy popularizados: el 
FORTRAN y el ALGOL 
Como tal lenguaje, el BASIC tiene su pro- 
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ti mundo de los lenguajes de programación guarda un gran paralelismo con ei de ios 
lenguajes humanos. Ex i sí en idiomas de mayor relevancia* como ei inglés, que constituyen 
verdaderos parrones de entendimiento universal. Esta característica se hace extensiva al 
ámbito de las máquinas, donde el BASIC se revela como el lenguaje más generalizado v 
universal. 



pió vocabulario y sus reglas sintácticas; y 
por supuesto, las particularidades inhe- 
rentes a los lenguajes destinados al diá- 
logo con los ordenadores. 
Está concebido para ser una herramienta 
a la hora de utilizar el ordenador; en_.su 
mayor parte consta de órdenes que la má- 
quina ha de ejecutar. 
La pragmática de ios lenguajes humanos 
se fundamenta en una unidad de comuni- 
cación: la frase. Combinando diversas fa- 
ses es como se establece una conversa- 
ción. Los diálogos en el lenguaje BASIC 
también se establecen a partir de frases, 
las instrucciones, que agrupadas ordena- 
damente dan cuerpo a un bloque de co- 
municación o programa. 
A la hora de construir cada una de fas 
instrucciones, el BASIC se acoge a una 
estructura semejante a la propia de las 
frases humanas. La combinación ade- 
cuada de sujeto, predicado y complemen- 
tos, permitirá expresar una idea con deta- 
lle y concreción. Dentro del vocabulario 
del BASIC, caben verbos adecuados para 
definir las más diversas acciones que de- 
ban realizarse con los datos, los sujetos 
de las instrucciones. En síntesis, Ja tarea 
de programar ai ordenador para que éste 
realice un trabajo, consistirá, sencilla- 
mente, en redactar una descripción deta- 



Glosario 

CONTROL DE PROCESOS: actividad en 
la que el ordenador se encarga de 
supervisar y controlar de forma 
automática determinados fenómenos o 
procesos externos. 



Hada del conjunto de tareas a ejecutar. 
Esta descripción de tareas, o programa, 
constará de una secuencia ordenada de 
frases (instrucciones), cada una de ellas 
destinada a ordenar la ejecución de una de 
fas tareas elementales La rigidez del or- 
den en el que deben ejecutarse las tareas 
que resuelven una actividad, se mani- 
fiesta en la numeración de las instruccio- 
nes dentro del programa. 
Verbos como «imprimir», «asignar», «sal- 
tai», «leer», «ejecutar»... forman parte del 
vocabulario de este importante lenguaje 
de programación. Tan importante como el 
uso correcto del vocabulario, es el estricto 
cumplimiento de las reglas sintácticas. El 
ordenador no comprenderá una palabra 
en la que se haya cambiado una letra; 
igual que nosotros no entendemos el sig- 
nificado de «casa» si por un error ortográ- 
fico leemos «cosa». Al detectar un error 



sintáctico, el ordenador lo comunicará al 
usuario por medio del correspondiente 
mensaje. 

La analogía con los lenguajes humanos 
llega hasta el punto de que también exis- 
ten dialectos del lenguaje BASIC; dialec- 
tos condicionados por Jas particularidades 
del programa traductor específico que re- 
side en cada ordenador. 
Hay dialectos o versiones más potentes, 
con un vocabulario más completo, que 
permiten una mayor flexibilidad en la re- 
dacción de las instrucciones. También hay 
versiones más sencillas, con un vocabula- 
rio más reducido. A lo largo de la obra, se 
acometerá eJ estudio práctico del lenguaje 
BASIC más completo y generalizado para 
ordenadores personales; un estudio que 
se completará con una descripción de las 
variantes sintácticas y semánticas que ca- 
racterizan a los dialectos más importantes. 



SENSORES: dispositivos que pueden 
medir o detectar ciertos fenómenos 
físicos (temperatura, presión...) 

UNIDAD DE DISCO FLEXIBLE: periférico 
que permite almacenar la información en 
un soporte físico externo denominado 
disco flexible. El soporte es un disco de 
plástico, sobre ei que se ha depositado 
una capa de material magnetizable en el 
que se graba la información. 

UNIDADES DE ALMACENAMIENTO: 
dispositivos que permiten almacenar la 
información manipulada por el ordenador, 
para su posterior recuperación y 
tratamiento. 

PROGRAMA: conjunto ordenado de 
instrucciones codificadas en un lenguaje 
de programación que comunican al 
ordenador una tarea a realizar. 
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Lenguajes 



Lenguajes informáticos 

Del lenguaje máquina 

a los lenguajes de alto nivel 



Ocurre en el universo de los se- 
res humanos y, por supuesto, 
también debía suceder algo 
semejante en el mundo de los 
llenadores. Las máquinas programables 
ideadas por el hombre, ocupan una torre 
:-: 5abel en la que la disparidad de los 
aguajes es tan acusada como pueda 
en la sociedad humana Al igual que 
sn el terreno de los lenguajes humanos 
_ a, algunos idiomas con mayor relevancia 
i fusión, utilizados como patrón de en- 
cendimiento (el inglés, el castellano o el 
sncés), en la Babe! de los ordenadores 
también existen algunos lenguajes con 
acosado protagonismo. Sin lugar a dudas, 
- más popular de ellos es el BASIC 
: Terminan aquí las analogías. En la so- 



ciedad humana, muchos idiomas presen- 
tan dialectos o variantes, más o menos 
distantes de la raíz original. Una realidad 
trasladable a los lenguajes informáticos, 
donde los dialectos y versiones del BASIC 
son casi tan numerosos como modelos de 
ordenadores, 

Cualquier exposición relativa a los lengua- 
jes informáticos, debe partir del personaje 
central: el ordenador. Sabemos que es 
una máquina cuya propiedad diferencia- 
dora reside en que admite una programa- 
ción que le permitirá realizar una ingente 
variedad de tareas: tantas como el usuario 
sea capaz de programar. 
Debido a su constitución íntima —un con- 
junto de circuitos electrónicos, de tecno- 
logía digital — , el ordenador está capaci- 
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A medida que ha evolucionado la informática 
han ido creándose nuevos lenguajes de 
programación, «de alto nivel», con una 
estructura semejante a la de ios lenguajes 
humanos. 



tado para entender un lenguaje construido 
a partir de dos elementos mínimos de 
información: 0 (ausencia de señal eléc- 
trica) y 1 (presencia de señal eléctrica) 
A partir de este alfabeto mínimo (0 y 1), 
pueden construirse palabras (01101110) 
y, por supuesto, frases [00110011 
11100011. ) con las que establecer una 
comunicación repleta de contenido. 
Algo es ya evidente: por su naturaleza, el 
ordenador está capacitado para dialogar 




L ALA MAQUINA 



El ordenador es una máquina capaz de recibir una programación y comunicarse con el mundo 
exterior. Ello es posible debido a la existencia de lenguajes que permiten establecer una 

üc ación organizada: éstos son tos denominados lenguajes de programación, clasificantes 
i categorías según sean más o menos próximos ai lenguaje íntimo de los circuitos 
rUc irónicos de la máquina. 
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en un lenguaje íntimo que denominare- 
mos lenguaje máquina, edificado a partir 
de dos elementos mínimos de informa- 
ción: 0 y 1. Estos elementos, Jos BfTs 
(contracción de su denominación inglesa 
Binary DígiT; dígito binario), coinciden con 
los propios del sistema de numeración 
binario. 



NIVELES DE LOS LENGUAJES 
INFORMATICOS 



La capacidad del ordenador para intercam- 
biar información con el usuario es un he- 
cho ya precisado. Por ef momento, hemos 
visto que es posible establecer una comu- 
nicación con sus circuitos electrónicos uti- 
lizando su lenguaje íntimo: el lenguaje 
máquina. Una simple reflexión acerca de 
esta vía de diálogo, nos lleva a algunas 



conclusiones no excesivamente favora- 
bles para el lenguaje máquina. En princi- 
pio, no cabe duda que se trata de un len- 
guaje difícil de aprender para el usuario; 
no sóío por la complejidad inherente a la 
estructura del propio lenguaje, sino tam- 
bién por el hecho de que su íntima rela- 
ción con ía máquina obliga a conocer muy 
a fondo sus entresijos. Además, hay que 
recordar que el ordenadores una máquina 
ignorante, a la que hay que instruir con 
toda suerte de detalles mínimos; una ta- 
rea ardua y difícil de llevar a buen término 
a base de combinar ceros y unos. 
Al fin y ai cabo, el ordenador no es más 
que una herramienta creada por el hom- 
bre para facilitar su trabajo... ¿Por qué hay 
que acondicionarse al lenguaje íntimo de 
la máquina, si cabe la posibilidad de comu- 
nicarse con ella utilizando un lenguaje pró- 
ximo al humano? Todo el problema se 
reduciría a crear los adecuados traducto- 
res, que convirtiesen las descripciones 
formuladas en lenguaje evolucionado en 
sus homologas en lenguaje máquina. 



BASIC 
básico 




Lú disparidad de lenguajes y la necesidad de 
medios de traducción que permitan el 
entendimiento, son realidades compartidas 
por los lenguajes humanos convencionales v 
tas lenguajes de programación. ' * 



Los principales lenguajes de alto nivel 



ADA 

(En honor de Lady Augusta ADA Byrori) 

La publicación de unas notas sobre la 
máquina analítica de Charles Babbage, le 
sirvió a ía condesa de Lovelace para pasar a 
la posteridad, cediendo su nombre al 
lenguaje que debía nacer def proyecto 
GREEIM. Fue en 1975 cuando se 
consumaron los trabajos del equipo dirigido 
por J, M. Ischbia de fa firma CII-HoneyweN 
Bul!, con el patrocinio del Departamento de 
Defensa de ios Estados Unidos. 
El ADA es un lenguaje inspirado en el 
PASCAL que se desarrolló con el objetivo 
de conseguir un lenguaje con posibilidades 
de convertirse en estándar universal y que 
facilitara el mantenimiento de fos 
programas. Actualmente, aún no está muy 
difundido, aunque muchos expertos lo 
consideran uno de los lenguajes con mayor 
futuro. 



ALGOL 

(ALGOrithmic Language. Lenguaje 
algorítmico) 

A raíz de un proyecto de Peter Maur en 
1953, un consorcio internacional promovió 



el desarrollo de un lenguaje de alto nivel, 
inicial mente para aplicaciones científicas, 
que algún tiempo más tarde se plasmaría 
en el ALGOL. A pesar de sus cualidades 
para cálculos numéricos, tratamiento de 
entradas/salidas y procesos recursivos, el 
ALGOL es uno de los lenguajes que no ha 
viajado con fa revolución m íc roí n forma tica. 

BASIC 

[Beginners All-purpose Symbolic 
ínstruction Code. Código de instrucciones 
simbólicas de uso general para 
principiantes} 

El más popular de los lenguajes actuales, 
sin lugara dudas, y a considerable distancia 
de los restantes lenguajes informáticos, 
Nació entre 1964 y 1965 en el Dartmouth 
College como una herramienta para la 
enseñanza. Con el tiempo, han ido 
prolif erando los dialectos y versiones, hasta 
el punto de que raro es el fabricante que no 
desarrolla un dialecto propio para sus 
equipos. 

Es muy difícil encontrar un ordenador 
personal que en su versión básica no 
inccrpore un intérprete de lenguaje BASIC. 
Desde hace algunos años, fa firma 
americana Microsoft Ndera el desarrollo de 



draiectos BASIC, disponiendo de algunas 
versiones {MBASIC, MSX-BASiC.) que se 
están conviniendo en núcleos de 
estandarización, 

«C» 

Uno de los más recientes lenguajes de 
programación de alto nivel. Dentro de este 
marco, el «C» es uno de los lenguajes más 
polivalentes y próximos a Ja realidad de fa 
máquina. La Bell Laboratories lo desarrolló 
en su origen para trabajar con el sistema 
operativo UNIX, La popularidad de! «C» 
crece día a día; ello permite catalogarlo 
como uno de los lenguajes del futuro. Su 
estructura sintáctica y semántica está 
edificada sobre conceptos tales como 
estructuración, jerarquizactán de bloques y 
controf def ffujo de datos, 

COBOL 

fCOmmon Business Oriented Language. 
Lenguaje orientado a la gestión) 

Sin lugar a dudas, se trata del lenguaje 
especializado en tareas de gestión que ha 
alcanzado una mayor resonancia. El 
Departamento de Defensa de los Estados 
Unidos, promovió su desarrollo en 1960. A 




Ex sté intimidad, el lenguaje de los circuitos de la máquina son complicadas secuencias de 
'threles de tensión; estados de conexión y desconexión que representamos por medio de 
: wnbinartones de ceros y unos. 



pesar de las críticas formuladas por algunos 
teóricos, expertos en lenguajes 
informáticos, su presencia es aún 
frecuente en m i n ¡orden adores y grandes 
equipos. No ocurre ío mismo en el terreno 
de los microordenadores; su 
representación en este campo se reduce a 
algunas versiones compiladas compatibles 
con el sistema operativo CP/VI. 

FORTH 

Un lenguaje difícil de catalogar, dada su 
distancia respecto a los restantes lenguajes 
de alto nivel. A pesar de acogerse al 
concepto de estructuración, el FORTH 
mantiene una acusada proximidad respecto 
al lenguaje máquina; con las contrapartidas 
que ello supone, en cuanto a velocidad de 
ejecución y reducida ocupación de 
memoria. Otra característica reseñable es 
su evolutividad; el FORTH permite al 
usuario crear sus propios comandos. Día a 
día crece su proyección en el ámbito de los 
microordenadores. En la actualidad existen 
compiladores o se mi -compiladores FORTH 
para un gran número de ordenadores 
cersonales. 

FORTRAN 

-ORmula TRANslation. Conversión de 
fórmulas) 

Su nombre evidencia la orientación 
matemática de uno de los más antiguos de 



los lenguajes que aún predominan en 
nuestros días. J. Backus lo desarrolló en 
1956 sobre un ordenador IBM 704. A pesar 
de su orientación primaría, el FORTRAN se 
ha revelado como un lenguaje adecuado 
para aplicaciones de gestión. 
Aunque ha perdido terreno frente a 
lenguajes más modernos, persiste su 
empleo de la mano de compiladores con 
versiones compatibles con sistemas 
operativos tan populares como el CP/M. 

LISP 

(LISt Processing. Procesado de listas) 

El Massachusetts Institute of Technology 
creó en 1959 este lenguaje de alto nivel 
orientado a aplicaciones de inteligencia 
artificial. La programación de procesos 
recurrentes [edificados sobre datos 
sintetizados en los pasos anteriores) es uno 
de los puntos fuertes del LISP. 
Dentro de su especialidad, es un lenguaje 
que sigue en plena vigencia, y del que 
existen compiladores para 
microordenadores y ordenadores 
personales. 

LOGO 

Seymour Papert, del Massachusetts 
Institute of Technology, creó en 1976 La 
primera versión del papular LOGO, 
inspirada en su anterior desarrollo: el 
lenguaje LISP 



Un razonamiento que derivó en la crea- 
ción de nuevos lenguajes informáticos 
más próximos al lenguaje convencional. 
El desarrollo de los lenguajes fue paralelo 
a la evolución de los ordenadores. Poco a 
poco, fueron naciendo lenguajes algo más 
alejados de la intimidad de la máquina y, 
más tarde, llegaron los denominados /er> 
guajes de alto nivel cuya sintaxis, semán- 
tica y pragmática eran ya semejantes a los 
del lenguaje humano. 
En nuestros días, la pirámide de los_.le.n- 
guajes informáticos consta de tres nive- 
les: 

• Lenguajes máquina. 
Ocupan el estrato inferior, menos evolu- 
cionado, de los lenguajes informáticos. 
Dada su total consonancia con la natura- 
leza íntima de la máquina, es obvio que el 
lenguaje será distinto según se trate de 
una u otra máquina. 

Cabe recordar que el cerebro o unidad 
central del proceso es el microprocesa- 
dor; en consecuencia, el lenguaje má- 



El LOGO es un lenguaje especialmente 
adecuado para la enseñanza asistida por 
ordenador Su celebridad se debe en gran 
parte a la simpática «tortuga» : el símbolo 
con cuyo desplazamiento se generan los 
dibujos y presentaciones gráficas. A pesar 
de su popularidad, es un lenguaje 
encasillado en el campo educativo. 
Permanece ignorado por los profesionales 
de la programación, aunque no es 
desdeñable su utilidad como herramienta 
para la simulación de fenómenos de 
inteligencia artificial. 

PASCAL 

(En honor del célebre matemático francés 
Blaise PASCAD 

Este es el !engua[e estructurado por 
excelencia, con una presencia más que 
importante en el mundo de los 
microordenadores. N. Wirth lo desarrolló en 
1969, en la escuela politécnica de Zurich, 
partiendo de los fundamentos del ALGOL. 
El PASCAL es un lenguaje muy adecuado 
para generar programas comprensibles y 
claros; ello se debe a su característica de 
lenguaje estructurado que obliga a la 
definición previa de todos los parámetros 
en juego 

La Universidad Californiana de San Diego, 
desarrolló la versión de PASCAL más 
popular en el campo de los 
microordenadores y ordenadores 
personales: el PASCAL UCSD. 



11 



Da ra cada ordenador de- 
\ del t|po de microprocesador que 
en su núcleo. En efecto, cada mi- 
: zz zi^ezz 6300, 6502 r 280...) tiene 
5 _ z'zz : e-gjaje máquina. 
• -e^z^í es de ensamble o 
t u-: Bjjres. 

- z- 5 r r : : ~ie r m edio está ocu pado po r los 
T _ ;_ = f= de ensamble. El repertorio de 
= ^e-iDs que intervienen en la confec- 
ción de los programas coincide, en este 
caso con conjuntos de símbolos o nemó- 

- dos, que ofrecen una mayor comodidad 

ss asociaciones de ceros y unos. 
Su reíación con el lenguaje máquina es 
muy próxima, hasta el punto de que cada 
familia de microprocesadores posee un 
lenguaje ensamblador propio, en directa 
correspondencia con su lenguaje má- 
quina. 

La tarea de confección y corrección de los 
programas resulta ahora más fácil, dada la 
comodidad que supone el emplear grupos 
de letras en lugar de ceros y unos para 



definir las operaciones. No cabe duda que 
para incrementar un número en una uni- 
dad, es más grato escribir INC A que 
00111100; y r desde luego, fa posibilidad 
de cometer un error es bastante más re- 
ducida. 

• Lenguajes de alto nivel. 
Estos son ya lenguajes evolucionados que 
mantienen un gran paralelismo con los 
lenguajes hablados convencionales. En 
este tercer nivel, la disparidad de Jos len- 
guajes no es achacable al microprocesa- 
dor. Los lenguajes de alto nivel más difun- 
didos (BASIC, PASCAL, FORTRAN, CO- 
BOL, LOGO . ) disponen de traductores 
para su conversión al lenguaje máquina de 
casi cualquier microprocesador 
Las ventajas son evidentes: la redacción 
del programa resulta comprensible para el 
usuario y, por lo tanto, es más cómoda su 
redacción y la detección de posibles erro- 
res sintácticos. Por lo demás se reduce el 
tiempo de programación y, lo que es más 




importante, cabe ya pensar en que un 
mismo programa pueda ser ejecutado por 
distintos ordenadores. 



LENGUAJES DE ALTO NIVEL 



Dentro del universo dé ios lenguajes de programación, caben desde lenguajes orientado, al 
dialogo especializado (gestión, cálculo, enseñanza,..), hasta lenguajes polivalentes útiles para 
programar cualquier tipo de aplicación. 
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El BASIC es, sin lugar a dudas, el lenguaje 
de alto nivel más popular en nuestros 
días, Un lenguaje de programación poliva- 
lente, que ha derivado en múltiples diafec- 
tos: desde versiones resumidas para el 
aprendizaje, hasta potentes y evoluciona- 
das versiones orientadas a la programa- 
ción profesional. Pero no arranca de ahí fa 
historia de los lenguajes informáticos. An- 
tes del BASIC y después del BASIC son 
muchos los lenguajes que han visto la luz' 
desde el SHORT CODE que en 1949 de- 
sarrolló el Doctor Mendy para la firma 
UNfVAC, o el SPEED CODJNG nacido en 
1953 con destino a IBM, hasta los más 
recientes como ef LOGO (1976), un len- 
guaje especialmente diseñado para la en- 
señanza asistida por ordenador. 
Los primeros lenguajes se desarrollaron 
pensando en aplicaciones matemáticas y 
científicas: tal es el caso del MATHMA- 
TJC, el GAL o el tradicional FORTRAN. 
Más tarde llegaron los lenguajes orienta- 
dos a la programación de aplicaciones de 
gestión, cuyo protagonismo corresponde 
al COBOL. 

Los lenguajes polivalentes o universales 
llegaron tras la estela del JOVIAL, el pri- 
mer lenguaje no especializado que vio la 
luz en 1959. A éste le siguieron el ALGOL 
PL/1, APL, BASIC, PASCAL, FORTK 
ADA, LOGO y otros muchos más. 
La popularidad de los ordenadores perso- 
nales ha arrastrado a algunos lenguajes de 
alto nivel; si bien, a su vez, ha relegado a 
otros lenguajes clásicos al ámbito de los 
min ¡ordenadores y ordenadores gigantes. 
Actualmente, tras el liderazgo del BASIC 
con sus múltiples dialectos, se alinea una 
corte de alternativas cuyos representan- 
tes mas significados son: el PASCAL 
LOGO, ADA, «C», FORTH y PILOT, ade- 
más de ciertas versiones actualizadas de 
los tradicionales COBOL (CIS COBOL y 
COBOL-80), FORTRAN (FORTRAN 77 
FORTRAN 80, FORTRAN SSS), LISP (MU- 
LISP) y PL/1 (con sus versiones PL/M 
PL/W, PL/Z...K 



s.o. 



El sistema operativo 

i 

La inteligencia elemental 
del ordenador 




símbolo más representativo 
de la época en que vivimos es 
una máquina llamada ordena- 
dor. Su aspecto externo, e 
muso su interior —una amalgama de cir- 
reos electrónicos— es semejante al de 
^chos otros aspectos especializados en 
| determinada tarea. Equipos de alta 
;elidad r receptores de radio y de TV, y 
ros sofisticados instrumentos electróni- 
33. están construidos a base de compo- 



nentes y dispositivos que también se en- 
cuentran en la intimidad del ordenador. 
¿Cuál es, entonces, la línea divisoria entre 
el mundo de las máquinas especializadas 
y del ordenador? 

La distinción esencial entre el ordenador y 
cualquier otra máquina reside en que el 
primero es una máquina programaba A 
diferencia con cualquier otro sofisticado 
aparato de los que inundan los hogares, 
oficinas, colegios, industrias el ordená- 




is línea divisoria entre el ordenador y cualquier otra sofisticada máquina electrónica, la 
* gablete la posibilidad de recibir ana programación. El ordenador es ana maquina 
z^ramable, con la que puede establecerse ana comunicación V a la que es posible mstrmr 
7*ira qae realice la actividad que desee el usuario. 



dor e s una máquina que el us uario puede 
j^c^ijjr para gnp reali ce una tarea espec í- 
fica y distinta en cada ocasión. 



LA INTELIGENCIA ELEMENTAL 
DEL ORDENADOR 



La tarea de «educación» de la máquina, se 
verá facilitada en gran medida si ésta 
cuenta con una inteligencia básica que 
agilice la comunicación entre el ordenador 
y el usuario. Semejante capacidad ele- 
mental debe brindar ai usuario los medios 
adecuados para que éste controle y ex- 
plote las posibilidades del ordenador. 

La inteligencia elemental con la que _bay 
que dotar a la máquina debe sintetizaras 
grupos de funciones, o capacidades bá- 
sicas: 

• Crear el entorno adecuado para el diá- 
logo hombre/máquina. Tarea que supone 
el control de ios dispositivos periféricos a 
través de los que se establece la comuni- 
cación entre el usuario y el ordenador: 
teclado, pantalla de visualización, impre- 
sora... 

• Gestionar de forma automática la lec- 
tura "y el almacenamiento de información 
(programas y datos) en las unidades de 
memoria, que forman, parte del sistema 
ordenador: unidad de cinta, de disco... 

• OJrecér_al usuario los medios adecua- 
dos para el tratamiento de ios archivos e 
información y para el conocimiento de su 
estado y situación en cualquier instante. 
El cometido de la inteligencia básica del 
ordenador es evitar, en definitiva, la com- 
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pleta programación del hardware de la 
máquina cada vez que el usuario se decida 
a utilizaría, 



EL SOFTWARE DEL SISTEMA 




Dada la naturaleza del ordenador, una dua- 
lidad circuí te na física/programación 
(hardware/software), resulta evidente que 
al hablar de dotarlo de una inteligencia 
básica, estamos apuntando a un elemento 
software que, de modo permanente, ins- 
truya a la máquina y ¡a ponga en situación 
de entablar un diálogo con el exterior. 
La «educación?) de fa máquina para reali- 
zar cada una de las funciones necesarias, 
correrá a cargo de un determinado nú- 
mero de programas. En su conjunto estos 
programas, que denominaremos software 
del sistema, constituyen la inteligencia bá- 
sica del ordenador. 

No está de más recordar que el hardware 
debe ser permanentemente instruido, 
hasta el más mínimo detalle, para que 
pueda manifestar su capacidad en el trata- 
miento de información (objetivo de cual- 
quier ordenador), 

En los ordenadores más pequeños, son 
escasas las funciones del software del 
sistema. Su actuación se manifiesta, úni- 
camente, en funciones tales como instruir 
al ordenador para que detecte una acción 
sobre el teclado, identifique cuál ha sido fa 
teda pulsada y lleve su valor a la pantalla 
al tiempo que lo almacena en la memoria 
También suelen ofrecer al usuario la posi- 
bilidad de examinar Ja información alma- 
cenada en determinadas zonas de la me- 
moria, e incluso, de observar cuál es el 
estado de algunos registros internos. 
A med ida que el orden adoras, jnás-pg- 
tejjte ^evQlucionado. crecen las nubili- 
dade s de su inteligencia elemental En la 
actualidad, ordenadores personales sue- 
len poseer un software del sistema que 
ofrece al usuario posibilidades más que 
notables. Permiten a éste encomendar a 
la máquina muy diversos tipos de accio- 
nes, sin más que ordenarlo introduciendo 
el comando al efecto 
En los equipos más pequeños, el soft- 
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JníltÉV K t ? T dC ! ÍCa de¡ ordenüdot : d í pende de lu ^existencia de dos elementas 

indisolubles, el «hardware» o etrcmtería física y id «software* o componentes de la 
programación. 




%?¿^T 0S . 0n t ena< f 0reS pOSeen """ '"" / '><"'<-'« elemental cada ver. más evolucionada 



ware del sistema adopta la forma de un 
programa, grabado permanentemente en 
su memoria Este recibe un nombre tan 
ilustrativo como es el de programa moni- 
tor. Cuando el ordenador es ya una má- 
quina evolucionada, como es el caso de 
un ordenador personal para aplicaciones 
profesionales o de gestión, el software 
del Sistema consta de todo un «paquete» 
de programas que obedece a la denomi- 
nación genérica de Sistema Operativo 
(S.O. al reducirlo a las iniciales). 



¿QUE ES UN SISTEMA 
OPERATIVO? 



Al extraer fas conclusiones de ios aparta- 
dos precedentes, surge la definición de 
sistema operativo; 

Conjunto de programas quo constituyen 



^eiigencia básica del ordenador y 
s misión es crear ef marco adecuado 
jna eficaz comunicación entre el or- 
lador y el usuario o mundo exterior. 

. - a llegada del microprocesador, los 
—enadores han reducido su tamaño 
^ta el punto de que cualquier moderno 
- :-oordenador u ordenador personal 
□tede competir, e incluso superar, a sus 
epasados, docenas de veces más volu- 
—¡rosos y lentos, La revolución no sólo se 
-"ifiesta en la vertiente hardware de los 
- : . pos, sino también en el software, y no 
Ge a ser menos en el terreno de los siste- 
-as operativos. 

" : i son las consecuencias de la evolu- 
3Ói de los sistemas operativos: 

• B constante avance en ia potencia y 
-acidad de tratamiento. Cada vez son 
■ . ares las posibilidades de los sistemas 



operativos: pueden controtar a un mayor 
número de periféricos asociados al orde- 
nador, ponen a disposición del usuario un 
repertorio de comandos más amplío y po- 
tente y r un factor de gran importancia, 
ponen en práctica nuevos métodos, más 
eficaces y rápidos, para explotar las posi- 
bilidades del hardware de la máquina. 

• Una acusada tendencia hacia la estan- 
darización. Hasta hace algunos años, la 
disparidad de los sistemas operativos era 
casi absoluta. A medida que creció el nú- 
mero de ordenadores, se avanzó en la 
idea de que compartieran un mismo cere- 
bro circuital (el procesador o CPU). La lle- 
gada del microprocesador, y su implanta- 
ción como cerebro de los microordenado- 
res, supuso un definitivo avance en el ca- 
mino hacia la estandarización de los siste- 
mas operativos. 



En la actualidad son muy pocos los tipos 
de microprocesadores que ostentan el li- 
derazgo del «mercado de cerebros» para 
microordenadores. Z-80 r 6502 r 6809, 
8086, 8088 y 68000, son los nombres de 
estos microcerebros que, alojados en una 
superficie no mayor que un sello postal y 
recubiertos por una simple cápsula de 
plástico o de cerámica, están dispuestos a 
ejecutar con premura y eficacia las órde- 
nes que reciban del mundo exterior. 
Semejante uniformidad ha hecho posible 
que un mismo sistema operativo pueda 
ser compartido por una amplia variedad de 
ordenadores, cuya CPU está basada en un 
mismo tipo de microprocesador. 
Desde luego, el camino hacia la estandari- 
zación es aún incipiente, Hoy siguen 
siendo múltiples los sistemas operativos 
que coexisten en el mercado, con una 
mayor o menor implantación. Si bien, un 



CIRCUITERIA 




El ordenador: una dualidad 
hardware/software 



La actuación del ordenador, protagonista 
del universo informático, no depende 
exclusivamente de la complicada y precisa 
conjunción de circuitos electrónicos que 
observamos al descubrir su interior. Su 
funcionalidad depende de una dualidad., de 
la asociación de dos factores: 

El HARDWARE o estructura física: 
conjunto de componentes, circuitos y 
dispositivos que integran la máquina. Él 
SOFTWARE o elementos «intangibles)» 
que pueden ser modificados o sustituidos: 
conjunto de órdenes, instrucciones y 
programas que «educan» a la estructura 
física y determinan el comportamiento 
específico de la máquina. 

Las raíces de estos dos términos 
anglosajones, ilustran perfectamente su 
acepción informática. 

HARD significa, ni mas ni menos que duro; 
y en efecto, se utiliza para designar, 
genéricamente, a la totalidad de 
componentes y circuitos electrónicos que 
constituyen el ordenador. 

Por contraposición, la raíz SOFT (blando) da 
cuerpo al término que identifica a la 
globalidad de elementos de programación, 
que convierten a la estructura física en una 
máquina programadle: el ordenador. 
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i@Ácjtfü grupo de ellos — fos sistemas 
operativos CP/M y MS/DOS, básica- 
ocupan un liderazgo destacado, 
- 3~dose ;omo protagonistas de' 
= 5 -:-r - = :.'s a estandarización. 



FUNCIONES DE UN 
SISTEMA OPERATIVO 




La presencia del sistema operativo en los 
ordenadores responde a dos objetivos bá- 
sicos. El primero no es otro que convertir 
a la máquina en un ordenador, practicable 
y eficaz, con capacidad para iniciar un diá- 
logo con el mundo exterior. De esta situa- 
ción parte ef segundo de los objetivos del 
S.O,: explotar al máximo Jos recursos y 
posibilidades del hardware del ordenador 
para que su uso sea el óptimo. 
La puesta en práctica de ambos objetivos 
básicos, exige af sistema operativo una 
notable capacidad de gestión y proceso. 
Capacidad que se resume en tres niveles 
funcionares compartidos por cualquier sis- 
tema operativo evolucionado, 

• Gostión del propio sistema ordenador, 
lo que equivale a supervisar y controlar 
tanto ef funcionamiento de la unidad cen- 
tral, como el de las unidades periféricas 
asociadas (pantalla, teclado, impresora, 
unidades de almacenamiento...). 

• Gestión de los trabajos encomendados 
a la máquina. El control y tratamiento de 
las tareas que se le han encomendado, 
exige aJ sistema operativo capacidad para: 

— Planificar los trabajos, respetando fas 
prioridades que pudieran haberse otor^ 
gado a cada uno de ellos. 

— Asignar los recursos de la máquina 
para la eficaz resolución de las tareas a 
procesar. Ello se traduce en la asignación 
y reserva de zonas de memoria, dedica- 
ción de periféricos adecuados para cada 
actividad y control de Jos mismos. . 

— Supervisar y establecer las comunica- 
ciones oportunas con el entorno, tanto 
para la carga de programas y datos, como 
para entregar Jos resultados aJ exterior 



• Gestión de datos. Con toda la actividad 
que conlleva la estructuración de archivos, 
el acceso a los mismos, el control de los 
soportes de memoria externa y la propia 
verificación y manipulación de fos datos. 
Un repaso a las funciones que incorpora eJ 
sistema operativo, revela su perfecta ade- 
cuación a fas exigencias que se imponen a 
Ja «inteligencia elemental» de la máquina. 



En efecto, las tres funciones básicas c 
un S.O. contribuyen a crear el entorr 
adecuado para la comunicación hombre 
máquina, gestionan la lectura y el almací 
namiento automático de la informacíc 
(programas y datos) y, por último, ofrece 
al usuario los medios adecuados para 
tratamiento de los archivos e informan di 
estado del sistema en cualquier instante 



El software del sistema 



Por su constitución física, hemos visto que 
el ordenador es una simple máquina; no 
más compleja que cualquiera de los 
sofisticados instrumentos electrónicos y 
equipos domésticos que han asaltado los 
hogares. Un entramado de circuitos 
electrónicos y dispositivos mecánicos de 
precisión que puede convertirse en un 
ordenador, capaz de recibir una 
programación y realizar innumerables 
funciones. 

El salto de máquina a ordenador es posible 
desde el trampolín que aporta a fa máquina 
ei software del sistema. Esta inteligencia 
elemental instruye a la amalgama de 
circuitos electrónicos para que puedan 
llegara establecer una comunicación con el 
mundo exterior. De esta forma, la máquina 
puede recibir una programación o 
educación para realizar las tareas que ef 
usuario desee. 

Tres son las misiones básicas 
encomendadas al software del sistema: 

• Crear el entorno adecuado para la 
comunicación hombre/máqu na. 



* Gestionar la fectura y el 
almacenamiento de información en las 
unidades de memoria. 

• Ofrecer af usuario los medios 
adecuados para el tratamiento de los 
archivos de información y para ef 
conocimiento del estado del ordenador en 
cualquier instante. 
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Software de aplicación 



El último nivel 

iel edificio informático 



Aplicaciones 




egún los expertos, más del 
cincuenta por ciento del mer- 
cado informático está ocupado 
por el software. Un concepto 
:.e engloba a la totalidad de elementos 
r.e intervienen en la educación del hard- 
ware o circuitería física de la máquina, y 
aue convierten a ésta en un verdadero 
zrdenador. 

Rmbos aspectos, hardware y software, 
sen indisolubles. Su complementan edad 
es la que determina la existencia de la 
--'ormática. 



¿BASTA CON UN SO. Y UN 
TRADUCTOR DE LENGUAJE? 



incluso programas más desarrollados, 
destinados a tareas bastante más comple- 
jas: contabilidad doméstica, archivo biblio- 
gráfico personal, control de movimientos 
de las cuentas bancarias... 
La gestión de aplicaciones complejas 
exige la presencia en el ordenador de un 
software de aplicación especializado, 
complejo y optimizado. 



De máquina a ordenador. Una es! rae tura a 
edificar sobre los cimientos de! hardware y 
que, a! completar los sucesivos ni ce les. dará 
lugar al nacimiento del ordenador: un 
disciplinado y eficaz colaborador en 
cualquier actividad. 



-srtiendo de la máquina desnuda, del 
-rdware, hay que llegar a construir un 
: Cenador con toda su capacidad y posibi- 
idades prácticas. Semejante edificio, 
:cnsta de varios niveles. En una primera 
r:apa, hay que revestir al hardware de lo 
zje denominaremos la «inteligencia bá- 
ica»; el sistema operativo. Sobre este 
orimer nivel, es posible ya implantar el 
- r. ductor de lenguaje que permitirá esta- 
z ecer un diálogo organizado con la má- 
quina. 

_-- Transformación de la máquina en la útil 
-srramienta práctica que conocemos, se 
x>mpleta al ocupar el tercer nivel del edifi- 
; : : al dotar al ordenador del software de 
:ación. Este puede estar constituido, 
rencillamente, por programas confeccio- 
nados por el usuario en el lenguaje que es 
capaz de reconocer el traductor Progra- 
nas de juego, programas adecuados para 
-^alizar cálculos matemáticos o para ges- 
-cnar la agenda telefónica personal... O 





Para dar a la máquina toda su eficacia práctica* no hasta 
y un traductor de lenguaje. La «instrucción» para realizar 
mano de los programas de aplicación. 



ron dotarla de 
cualquier activ 



un sistema operativo 
(dad la recibe de la 
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- . :^ai como puede ser 

■ :t _- £ -chivo de clientes, se ve 
" : . : : := - : sda al sustituir los mé- 

" ^5 es de archivo por un or- 
t :::¿c: de un software de aplica- 
: : _ - t tI.i Este consistirá en un con- 
jamoo «naquete» de programas (de ahí la 
:t~ - ---- t" de «paquetes de aplica- 
enn L Cada uno de los programas, desti- 
~ i ? -eso. ver una tarea especifica 
:-: r- ^a je ficha a nuevos clientes, rela- 
ción de clientes con facturas pendientes 
ce oago...), se ejecutará al seleccionar la 
correspondiente tarea en una relación de 
opciones o menú. 

En la medida en que crece la complejidad 
de las aplicaciones, éstas suelen obviar la 
presencia del traductor de lenguaje. Para 
optimizar su volumen (memoria necesa- 
ria) e incrementar su velocidad, estas apli- 
caciones suelen estar escritas en lenguaje 
máquina y H por consiguiente, no exigen la 
presencia del traductor de lenguaje de 
afto nivel. Dentro de la estructura soft- 
ware del ordenador, estas aplicaciones se 
apoyarán sobre el nivel ocupado por el 
sistema operativo. 

Las aplicaciones más simples o que no 
exigen una elevada velocidad de ejecu- 
ción, pueden introducirse directamente 
en lenguaje de alto nivel. En consecuen- 
cia, al tratarse de programas fuente, es 
necesario contar con el traductor ade- 
cuado que se ocupe de su conversión al 
lenguaje propio de la máquina. 



¿COMO PROVEERSE DEL 
SOFTWARE DE APLICACION? 




La mayor parte de las aplicaciones habi- 
tuales de los ordenadores no suelen ser 
creaciones del propio usuario. La inver- 
sión en tiempo o en adquisición de cono- 
cimientos y utilidades para la programa- 
ción, son algunos factores que mueven al 
usuario a optar por programas comercia- 
les. A estos condicionantes, hay que aña- 
dir las contrapartidas que aportan muchos 
programas comerciales; por ejemplo., per- 
miten una estandarización de las aplica- 
ciones que facilita el intercambio de da- 
tos, conocimientos y soluciones entre los 
usuarios de una misma aplicación. 
En definitiva, a Ja hora de dar contenido al 
tercer nivel del edificio de la programa- 
ción, el usuario cuenta con tres alternati- 
vas básicas: 

• Crear sus propios programas de apli- 
cación. 

• Encargar la confección de programas 
«a medida», 

• Adquirir programas estandarizados. 
La primera alternativa, resulta adecuada 
cuando se trata de confeccionar progra- 
mas sencillos o destinados a aplicaciones 
cuya originalidad lo aconseje. No obs- 



tante, ésta no es una alternativa genera • 
zable, puesto que, como ya se ha indi- 
cado, la complejidad de las aplicaciones 
puede convertir la tarea de programador 
en una empresa imposible, antieconómica 
o, en el mejor de los casos, puede exig> 
una excesiva inversión de tiempo. 
Cuando las aplicaciones alcanzan una 
complejidad sustancial y deben ajustarse 
a unos criterios muy específicos, resulta 
conveniente encargar los programas «a 
medida». Cada vez son más las empresas 
dedicadas a la creación de software a me- 
dida. Su actividad primordial reside en el 
campo de las aplicaciones administrativas 
y de gestión especializada, para profesio- 
nales o empresas. Hay que tener en 
cuenta que la disparidad de situaciones 
que se plantean a la hora de gestionar la 
actividad de un almacén, o el control de 
una red comercial, reduce Jas posibilida- 
des de estandarizar los respectivos pro- 
gramas y paquetes de aplicación. 



CATEGORIAS DEL SOFTWARE 
DE APLICACION 



Son muy diversos los criterios que pue- 
den adoptarse para clasificar el software 
de aplicación destinado a ordenadores 



A ta hora de proveer ai ordenador del 
adecuado software de aplicación, el usuario 
cuenta con tres alternativas básicas: crear 
sus propios programas, encargarlos 
«a medida * o adquirir programas 
es t a ndarizados . 




Los programas de juego constituyen el grupo más extenso y popnfar del software de 
aplicación. 
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Aplicaciones 



SOFTWARE 



DE 



APLICACION 



personales El primero y más genérico 
lleva a la distinción entre programas pro le- 
siónales, auxiliares o de utilidad y lúdicos. 
Un segundo criterio de clasificación, me- 
nos genérico que el anterior, conduce a la 



¿Para qué sirve un ordenador personal? La 
respuesta cabe encontrarla en el ingente 
repertorio de programas capaces de resolver 
J las tareas más dispares. 







\l 


EDUCACION 



CIENTIFICO/ 
TECNICO 




distinción de cinco grupos fundamentales 
de programas y paquetes de aplicación: 

• Juegos/Entretenimiento 

• Educación 

• Productividad y gestión 

• Científico-técnicos 

• Contabilidad y administración 

Cada uno de los anteriores grupos admite, 
a su vez, una clasificación específica por 
categorías de funcionalidad. 

JUEGOS 

Este grupo engloba a los programas más 
populares en el terreno de los ordenado- 
res personales que ocupan el estrato infe- 
rior {ordenadores de bolsillo y familiares); 
si bien, también abundan los programas 
lúdicos destinados a ordenadores perso- 
nales más evolucionados, por ejemplo, 
para equipos profesionales como los mo- 
delos de la firma Apple o para el 1BM-PC 
Dentro de este apartado, cabe diferenciar 
entre varias categorías de juegos: juegos 
denominados de «arcade», entre los que 
destaca el popular «Space Invaders» o el 
más reciente «Zaxxon»; juegos de aven- 
turas, de acción, de estrategia y de simu- 
lación, además de los clásicos y no por 
ello menos interesantes, como son el aje- 
drez, damas, Monopoly, Othello o Inte- 
lect. 

EDUCACION 

Dentro de este apartado caben desde pro- 
gramas para el estudio de matemáticas, 
geografía o historia, hasta complejos pro- 



jefe de ventas 



Desde simples programas para el estudio de los conceptos 
matemáticos, hasta complejos paquetes para «enseñanza asistida 
?or ordenador». Un vasto marco de aplicaciones didácticas cayo 
eco es notable en el mu mío del software de aplicación. 



Las herramientas creadas para la ayuda a la gestión (hojas 
electrónicas, gestores de bases de datos, tratamientos de textos...), 
han convertido ai ordenador personal en un inapreciable colaborador 
del profesional y del gestor de empresa. 
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gramas de enseñanza as s: .: : - : -rs -s- 
dor para el aprendizaje de idiomas o de 
lenguajes de programación de alto nivel 
(BASIC, PILOT r LOGO...). 

PRODUCTIVIDAD Y GESTION 
El mayor segmento del mercado de soft- 
ware estandarizado lo ocupa esta catego- 
ría del software de aplicación. Tratamiento 
de textos, hojas electrónicas, gestores de 
bases de datos, generadores de progra- 
mas, paquetes para la generación de gráfi- 
cos o para el establecimiento de comuni- 



caciones entre equipos, Sin olvidar a los 
nuevos paquetes integrados mu It ¡funcio- 
nales (Lotus 1.2.3, Open Access, Synv 
phony...). Todo un repertorio de herra- 
mientas habituales que permiten al orde- 
nador personal acometer con éxito aplica- 
ciones de gestión y productividad. 

CIENTIFICO-TECNICOS 
Los profesionales cuentan con un amplio 
catálogo de aplicaciones, creadas para 
apoyar casi cualquier tipo de actividad 
científica con la colaboración del ordena- 



dor personal. Programas destinados a 
fesionales de la medicina (gestión de 
tos de los pacientes y archivo de diag 
ticos), aplicaciones para arquitectos, a 
gados, ingenieros... 

CONTABILIDAD Y ADMINISTRACION 
Sin lugar a dudas, éste es uno de los 
pos de aplicaciones que más ha pot 
ciado la difusión del ordenador pers 
en el ámbito de la empresa: gestión de 
contabilidad, nóminas, almacén, cont 
de pedidos, libro de vencimientos... 



El ordenador 
en actividad 



La expansión de los ordenadores y su 
vertiginosa entrada en todos los campos de 
actividad, es paralela a la andadura del 
software de aplicación, Los cada vez más 
potentes y perfeccionados paquetes de 
aplicación amplían el área de actuación del 
ordenador, con virtiéndolo en una 
herramienta insoslayable en fas tareas más 
dispares. 

Uno de tantos ejemplos lo obtenemos en el 
trabajo periodístico. Máquinas de escribir, 
lapiceros, gomas de borrar, ingentes 
archivos de datos, referencias y citas, 
ceden su paso ai ordenador. 





Un simple ordenador personal dotado de su 
correspondiente sistema operativo, 
completado con un paquete estandarizado 
de tratamiento de textos y una impresora, 
constituyen el entorno de trabajo del 
periodista o del escritor actual. 

La goma de borrar, fa ineludible tachadura e 
incluso la imagen de la papelera repleta de 
originales descartados, se diluye ante fa 
potencia de un tratamiento de textos. 

La edición del texto en la pantalla está 
apoyada por un amplio repertorio de 
funciones: borrado de caracteres, pafabras, 
lineas y párrafos; inserción de nuevo texto 
dentro de un original en edición; 
redistribución de párrafos y apartados; 
inclusión automática de textos anteriores... 

Funciones que permiten una cómoda 
edición y puesta a punto de los originales 
que se almacenarán en un simple disco 
flexible. Y que, además, garantizan una 
impresión final impecable, en ta que es 
posible definir con detalle cualquier 
precisión relativa al formato de escritura y a 
la distribución del texto sobre el papel, 
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Educando a la máquina 

Lenguaje, programas, 

instrucciones y comandos 



ODO ordenador personal está 

«regido por un minúsculo cere- 
bro, el microprocesador, cuyo 
aspecto es el de un rectángulo 
ie plástico negro, flanqueado por un gran 
número de patillas metálicas. En su inte- 
ior se alojan una gran cantidad de disposi- 
tivos electrónicos, integrados hasta el 
□unto de ocupar un volumen microscó- 
□ico. En su conjunto, constituyen un pe- 
culiar circuito lógico, capaz de gobernar su 
propia actividad y la del resto de los circui- 
tos que componen el ordenador. 
Semejante cerebro integrado puede reali- 
zar casi cualquier tipo de operación con 
os datos que reciba; no obstante, tiene 
una seria limitación: alguien ha de comu- 
nicarle lo que debe hacer, es preciso ins- 
truirlo con toda suerte de detalles, 
p ero,,,, ¿cómo hay que hablar con el orde- 
nador? Debido a la naturaleza de su cere- 
oro, un circuito electrónico lógico, resulta 
obvio que podremos comunicarnos direc- 
tamente a base de sucesiones de unos y 
ceros: empleando el lenguaje máquina, ni 
más ni menos. Cualquier frase formulada 
en este lenguaje, tiene el aspecto externo 
de una cadena de unos y ceros. Para un 
observador ajeno a las artes de programa- 
ción, su significado es críptico; sin em- 
bargo, para et ordenador representan las 
únicas órdenes e instrucciones que puede 
entender y ejecutar. 



EL ARTE DE DIALOGAR 
EN BASIC 



CORSO PE BASIC 

.NPÜT PR1NT 
L€l «OTO 



Aunque el lenguaje 
propio del ordenador es 
el código máquina, 
también es posible 
instruirlo para que 
admita, reconozca y 
ejecute las órdenes 
expresadas en un 
lenguaje de aito nivel: el 
BA S IC , por eje mp lo . 



Si el ordenador sólo es capaz de entender 
os arcanos del cero y el uno, ¿cómo es 
cosible que los ordenadores entiendan el 




El BASIC es un lenguaje que suele 
utilizarse en un ámbito de coma nú ación 
interactiva, de ahí que, normalmente, la 
traducción dei lenguaje BASIC se 
encomiende a un programa «Intérprete*. 
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repertorio de frases, muy parecidas al len- 
guaje ordinario, que pueden construirse 
con ef vocabulario de un lenguaje evolu- 
cionado como el BASIC? 
Nada más sencillo... ¿Para qué están los 
traductores? Dada la enorme capacidad 
de trabajo de! ordenador, también podrá 
encargarse de convertir nuestras frases 
en BASIC a ías secuencias de ceros y 
unos de su propio lenguaje interno 
La máquina aguarda a que se fa instruya, y 
no hay óbice que impida que el primer 
programa que reciba sea, precisamente, 
un traductor. Como ya sabemos, los tra- 
ductores de lenguajes pueden ser de dos 
tipos: intérpretes o compiladores. 




pida, es obvio que resultará más ade- 
cuado sustituir el intérprete por un compi- 
lador BASIC. 

La ejecución de un programa compilado 
(traducido en bloque) es bastante más rá- 
pida que fa ejecución de un programa ca- 
nalizado a través de un intérprete. Vol- 
viendo af ejemplo anterior, fa conferencia 
se prolongará por más tiempo si un intér- 
prete debe traducir frase a frase la diserta- 
ción del conferenciante; por el contrario, 
sí el texto de la conferencia se traduce de 
una sola vez (tarea del compilador) y se 
entrega traducido a los presentes, Ja dura- 
ción de la conferencia será bastante más 
breve. 

A la hora de establecer un primer contacto 
con el mundo de la programación en BA- 
SIC, o incluso acometer la confección de 
programas, el intérprete BASIC se revela 
como un eficaz auxiliar Entre sus funcio- 
nes están las de detectar errores y comu- 
nicarlos al usuario, además de facilitar las 
tareas de corrección y depuración de los 
programas. 



10 REM ***************************************^****** 

20 REM ** POSICIONAMIENTO DEL CURSOR ** 

30 REM ** EM PANTALLA ** 

40 REM *************************^ 

50 CLS 

60 LETX=10: LET Y=15 

70 PRINT AT (X,Y); "*" 

80 PRINT AT (X,Y-1); " " 

90 PRINT AT(X,Y+1); " " 
100 LET B$=INKEY$: IF B$="" THEN GOTO 100 
110 IF B$="W" THEN LET Y=Y-1 
120 IF B$="Z" THEN LET Y=Y+1 
130 IF B$="A" THEN LETX-XM 
140 IF B$="S" THEN LET X=X-H 
1 50 IF X>30 THEN LET X-30 
160 IF X<0 THEN LETX=0 
170 IFY<1 THEN LET Y- 1 
180 IF Y>20 THEN LET Y =20 
190 GOTO 70 



Una instrucción es una palabra o frase que 
educa ala máquina para que ejecute una 
operación a tarea específica. Agrupando un 
determinado numero de frases es posible 
construir un programa, capaz de instruir a ta 
máquina para que realice una actividad 
completa. 

Ef BASfC es un lenguaje que suele utili- 
zarse en un ámbito interactivo y, por ello, 
se emplea habitualmente a modo de len- 
guaje interpretado. 

Cabe recordar que la actuación del pro- 
j grama traductor tendrá un total parale- 
lismo con la realidad cotidiana. Por ejem- 
plo, si un científico extranjero quiere dar 
una conferencia y ni él sabe castellano, ni 
eí público conoce su idioma, caben dos 
soluciones: que un intérprete vaya tradu- 
ciendo su disertación, paso a paso, o que 
se reparta una hoja con el contenido ya 
traducido. 

En efecto, el ordenador no entiende el 
lenguaje BASIC directamente, sino que 
antes de asimilar su contenido, debe tra- 
ducirlo a su propio código (el lenguaje má- 
quina). Tal como ya hemos señalado, las 
comunicaciones con la máquina en BASIC 
son, con frecuencia, interactivas; de ahí 
que el traductor de BASIC a lenguaje má- 
quina sea, habitualmente, un intérprete 
de BASIC No obstante, cuando el BASIC 
se utilice para programar tareas comple- 
jas, cuya posterior ejecución debe ser rá- 



Ás pecio de un programa en lenguaje BASIC. 



INSTRUCCIONES Y PROGRAMAS 



Al igual que cualquier lenguaje humano, el 
BASIC se rige por un conjunto de normas 
semánticas y reglas sintácticas cuya 
puesta en práctica permite construir men- 
sajes organizados. La base del lenguaje se 
encuentra en su vocabulario o repertorio 
de palabras a través de fas cuales es posi- 
ble expresar cualquier acción programable. 
El vocabulario del BASIC está constituido 
por palabras del idioma inglés. Un vocabu- 
lario bastante más simple y limitado que el 
de cualquier lenguaje humano, pero sufi- 
ciente para construir fas órdenes destina- 
das a fa máquina Tal como ocurre en los 
diálogos humanos, la unidad de comuni- 
cación se encuentra en la frase, o con- 
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. de palabras que expresan una deter- 
— -¿úa acción, En el caso de[ BASIC, la 
^cad de comunicación se denomina ins- 

:ción. 

, 3¡eto de una instrucción es «educar» 

llenador para que éste realice una 

^ específica, 
-capando un cierto número de frases, es 
Estile expresar una actividad completa 
-rr todos sus matices, Lo mismo ocurre 

el ámbito de los lenguajes de progra- 
mación al asociar un determinado número 
- "Strucciones destinadas a la máquina. 
: i^njunto organizado de instrucciones 

- definen una tarea completa recibe el 
ore de programa. 

_ estructura de las frases del lenguaje 
;^jn se mantiene, con ligeras salveda- 

• en las frases o instrucciones que 
□riman un programa en lenguaje BA- 

SC. Un verbo es quien define la acción a 
- : zar por el sujeto; análogamente, jjh 

- -and o es elo u e indic a J a acción_ gue 
zEce reali zar el ordenador c on los dato s. 

una instrucción^BASIC intervienen dos 
Tras: 

» lomando 
• -^gu mentó 

-amando (semejante at verbo de una 
fase convencional) expresa la acción. 

5 puede coiriicidijLC o n una simDj e^pr- 
z^z desprovista de argum ento ^ dirigida a 
¿IjláciulnaTFor ejemplo: 

" " D : Detener la secuencia de ejecución, 
!*E*y Borrar por completo el programa 
Ocurso. 

■UN: Ejecutar el programa, 
.:"do la acción afecta a un dato, a un 
:o de datos, o a un dispositivo aso- 
; : al ordenador, el comando se acom- 
: = de una segunda zona denominada 
. . -vento. Si la instrucción incluye am- 
: zonas, el comando suele recibir et 

": "ore de sentencia. 

-ETA=2Q 
=?NT 430 
r"3 25 

"55 estas instrucciones incluyen una 

• :encia (comando) seguida por un argu- 
T*e^to que aporta el dato o datos implica- 

en la ejecución de la orden. Porejem- 
Mb, la primera instrucción apuntada (LET 

- =20) insta a la máquina para que asigne 

- 5 or 20 a la variable A. La segunda 
NT 430) comunica al ordenador que 

te*e a la pantalla el dato 430; mientras 
- GOTO 25 ordena un salto a la instruc- 
" " número 25. 




El ordenador doméstico , rodeado de un entorno mínimo, constituye im perfecto trampolín pura 
entrar en el mundo de ta programación en BASIC, 

INSTRUCCION 






PF 


INT 







1NT 



SENTENCIA 




FUNCION 



OPERADOR 



► END ' 

COMANDO 



PROGRAMA 

Dentro de un programa vahen muy diversos tipos de instrucciones. Estas pueden estar 
c onstituidas por un comando asociado a un argumento (dílto o datos relacionadas por 
funciones y ¡o operadores), o por un comando ais fado que expresa una orden. 



Dentro de la zona de argumento caben 
muy diversos tipos de datos y con distin- 
tas expresiones: valores numéricos, pala- 
bras o grupos de caracteres aifanuméri- 
cos r variables, referencias a dispositivos 
periféricos,.. Habitualmente, el argu- 
mento contiene varios datos relacionados 
entre sí por operadores (suma, resta, mul- 
tiplicación, igualdad...), o afectados por 
funciones, ya sean matemáticas o de 
cualquier otro tipo autorizado por el len- 
guaje BASIC. 



INSTRUCCIONES DIRECTAS 
E INDIRECTAS 



En un diálogo caben tanto frases sueltas, 
que dan pie a una respuesta inmediata, 



Basic 




► a un deter- 
Ests es una 
i aguaje BA- 
: - : -je i ordena- 
f insínjoción y aguardar 
I : t" : i - i puede co- 
iünu3¿ -s: , " e" : : s jna secuencia de 

- : . - n "Strucciones son las 
- - ^ se emplean de distinta 

■-— ■- : ^ stnjcción se utiliza de 

ÍHnuJeoer*áoite, para que la máquina 
a ejecute y curse una respuesta inme- 
i i i -e: ir e nombre de instrucción di- 
■-"= = ; - s rontrario, si ésta forma parte 
de un programa y se encuentra precedida 
por un número de orden que denota su 
Situación dentro del mismo, se estará for- 
mulando como instrucción indirecta. 
Al accionar la tecla RETURN tras una ins- 
trucción en modo directo, el ordenador la 
asimilará y ejecutará sin mayor dilación. 
Por ejemplo, si se introduce la instrucción 
LET A=20, al pulsar la tecla RETURN el 
ordenador asignará de inmediato el valor 
20 a la variable A. 

De forma análoga, tras dar la orden RE- 
TURN, después de introducir PRINT 35 
aparecerá en la pantalla et dato indica- 
do (35)- 

Arnbas instrucciones pueden agruparse 
dentro de un programa, lo que equivale a 
utilizarlas en modo indirecto. En este 
caso, cada instrucción debe estar prece- 
dida por un número (número de línea) que 
servirá al ordenador para discernir en qué 
orden debe ejecutarlas. Por ejemplo: 

10 LET A=250 
20 PRINT A 
■ 

Las instrucciones utilizadas en modo indi- 
recto, ya no son ejecutadas por el ordena- 
dor al accionar la tecla RETURN que pone 
fin a cada línea, Estas pasan a constituir 
un programa que será ejecutado en blo- 
que al introducir la orden al efecto: RUN, 



10 LET A-250 
20 PRINT A 
RUN 




En el ejemplo, al recibir la orden RUN, el 
ordenador ha ejecutado ambas instruccio- 
nes en el orden indicado por el número de 
línea que las acompaña. Al ejecutar la ins- 
trucción 10 (LET A=250) se asigna a la 
variable A el valor 250. Acto seguido, se 
ejecuta la instrucción 20 que ordena im- 
primir el valor de la variable A. 



ASPECTO DE UN 
PROGRAMA BASIC 



Como ya hemos visto, un programa es 
una secuencia ordenada de instrucciones 
que definen una tarea completa Las ins- 
trucciones se distribuyen en líneas sucesi- 
vas, cada una de ellas precedida por un 



número entero que señala el orden en e 
que será ejecutada por el ordenador. 
Los números de línea deben seguir un 
orden creciente. De esta forma, la ejecu- 
ción de la secuencia de instrucciones hará 
que el ordenador realice las sucesivas 
operaciones que conducirán al resultado 
final. 

Un programa redactado en lenguaje BA- 
SIC presenta una estructura semejante a 
la que sigue: 



10 INSTRUCCION 1 
20 INSTRUCCION 2 
30 INSTRUCCION 3 
40 INSTRUCCION 4 
50 INSTRUCCION 6 
55 END 




INSTRUCCION 5 




Una instrucción directa es la que se introduce 
desprovista de número de linear El 
ordenador ¡a ejecuta en el instante en el que se 
acciona la leda RETURN, entregando 
una respuesta inmediata* 
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E número de línea instruye al ordenador 
sobre el orden en el que debe ejecutar el 
:~: grama. Cabe observar que H excepto en 
r Jtima línea de instrucción, se han nu- 

- =rado las líneas a intervalos de 10. ¿Por 
: Er la práctica, e : primer intento de 
escritura de un programa muy raramente 
se ve coronado por el éxito; lo habitual es 
i-e queden en ei olvido algunas instruc- 

Brjnes. Numerando las líneas con un 
oerto intervalo, queda abierta la posibili- 
sd de añadir nuevas instrucciones en el 
.car oportuno, utilizando números de fí- 
intermedios. Recordemos que el or- 
i^nador ejecutará el programa atañ- 
endo estrictamente a un orden numé- 
~:o creciente; así pues, si hemos olvi- 
dado una instrucción intermedia entre las 
instrucciones 2 y 3 no tenemos por qué 
-escribir el programa completo, sino que 
bastará simplemente con escribir al final 
□e? programa la citada instrucción con el 
numero de línea «a propósito», por ejem- 
sato 24. El intérprete BASIC se ocupará de 
3_e las instrucciones añadidas posterior- 
mente se sitúen en el lugar que les co- 
~es ponda dentro de! programa, aten- 
iendo a su número de línea. 
^ 3 hora de escribrr un programa, la orden 
-£TURN tiene la misma importancia que 
e retroceso de carro» en el caso de una 
"áquina de escribir Al dar por concluida 

- escritura de una línea, resulta impera- 
do dar la orden RETURM Ef intérprete 
5ASIC responderá de inmediato, mos- 
~ndo en la pantalla el cursor o « indicador 

te oresencfa»; éste señalará la posición a 

I partir de la que se escribirá la próxima 
_ s:rucción. 

-.gunos intérpretes BASIC permiten la 
-Tritura de dos o más instrucciones on 
misma línea de programa. Las di ver- 
is instrucciones presentes en la misma 
~t3 se separan por medio de un carácter 
denominado «separador de instrucción», 
l~ el ejemplo propuesto (línea 40) las ins- 
xiones 4 y 5 se separan por medio del 
sgno 

"ecesidad de instruir al ordenador con 
rea suerte de precisiones, llega hasta el 
. . "" lo que es preciso señalar el final del 
_-:grama. De ahí que la última línea del 
™grama esté ocupada por una instruc- 
BASfC especializada en tal menester; 
fefca suele coincidir con la orden END. 
l35 instrucciones BASIC recuerdan a las 
: — ¡ulas matemáticas. Una semejanza 
- apunta la utilidad del BASIC para re- 
3D*ver problemas científicos. A pesar de 

- : el campo de acción de este lenguaje 



de alto nivel cubre todo tipo de disciplinas, 
desde los juegos y el aprendizaje hasta las 
tareas de gestión. Su naturaleza de len- 
guaje interactivo — el usuario recibe una 
respuesta instantánea a sus comunicacio- 
nes — , ha contribuido a que el BASIC sea 
el lenguaje más utilizado y popular 



EL COMANDO PRINT 



po, r concluida ta^nstrucci^n^on_la_orden 

rTeturn. 



PRINT 
BASÍC 



"BASIC" (RT) 



La primera impresión de que el ordenador 
es una máquina con capacidad práctica, la 
obtenemos al observar la pantalla repleta 
de mensajes y dibujos. De ahí que uno de 
los primeros objetivos de todo aquel que 



(RT): Acción sobre la tecla RETURN. 
Desde luego, la mayor parte de las veces, 
la instrucción PRINT se utiliza en modo 
indirecto, formando parte de un pro- 
grama. En este caso, y tal como puede 
observarse en el programa que sigue, la 
ejecución tendrá lugar al comunicarle al 
ordenador la orden RUN: 




Las instrucciones indirectas, o precedidas por an número de línea, se integran dentro de un 
programa (A y B) que sólo será ejecutado por el ordenador (C v D) ai recibir la orden RUN. 



empieza a programar sea, precisamente, 
escribir algo en la pantalla. 
EJ lenguaje BAS IC dispone de va rios-co- 
mandos especia]íza.c[o5-^-e^ta-J^eién ; 
eñíré^Tlo^'r^másJm portante es PRINT. 
Utilizándolo, en modo directo o indirecto, 
pueden llevarse a la pantalla los números, 
letras o palabras que desee el usuario. 
El formato . más simpl e de una instrucci ón 
PRINT es el que incluye e : mencionado 
comando, seguido por un texto encerrado 
entre comillas. Por ejemplo: 

PRINT "BASIC" 
PRINT "M-6727" 

PRINT "LENGUAJE DE PROGRAMACION" 

Al utiliz^u^a^stace-iófi-PRI^N^ en -modo 
directo (sjnmúmero de línea), el ordenado r 
llevara a la pantalla el texto, eac.errado-en- 
t re c ornil las, en el instante en el que se dé 



10 PRINT 
20 PRINT 
30 PRFNT 
40 END 
RUN 



"SOFT:" 

CURSO PRACTICO" 
"DE PROGRAMACION" 




SOFT: 

CURSO PRACTICO 
DE PROGRAMACION 



Cuando el dato a imprimir es un número, 
se omiten las comillas. Por ejemplo: 

10 PRINT 15 
20 PRINT 356.2 

Lo mismo ocurre cuando el argumento de 
la instrucción PRINT está constituido por 
nombres de variables, ya sean numéricas 
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i mprime erija pantalla los mensajes o el vator de ías ex^rg^inp^ gim a parean pn h 7nr\ ati& 
argumento. 

' í ) 

Formato: (Número de línea) PRINT <expre$ión 1> [,] [;] <expresión 2>... 

Ejemplos: PRINT 25 

1D PRINT 'SOFT" 

35 PRINT A,CS,"CURSO DE BASIC" 



Notación utilizada en el formato: 

< >: Los textos y expresiones encerradas por los símbolos "menor" o ' J mayor J ' son a po itació ndel usug rio . 
[ ]: Los elementos encerrados entre corchetes son opcjonales. 
{ }: Las llaves delimitan a los elementos alternativos . 



(A B, CL.) o de cadena de caracteres (AS, 
B$, CS...). En tal caso, la instrucción 
PRINT imprimirá los valores que estén 
asignados a las variables en cuestión: 

10 LET A$="EL NUMERO ES:" 
20 LET N=8 
30 PRINT A$;N 

Las anteriores instrucciones constituyen 
un verdadero programa, al que sólo hay 
que añadir la instrucción final END. Su 
ejecución, ordenada por medio del co- 
mando RUN, ilustra cuál es el efecto de 
los nombres de variables dispuestos en el 
a -acento de PRINT: 



10 LET AS- "EL NUMERO ES: 

20 LET N=8 

30 PRINT AS 

40 PRINT N 

50 END 

RUN 

EL NUMERO ES: 
8 



En efecto, el ordenador ha llevado a la 
pantalla el contenido de ambas variables: 
una cadena de caracteres en el caso de 
AS y un valor numérico en el de la varia- 
ble N. 

No terminan aquí las posibilidades de esta 
versátil instrucción El argumento de 
PRINT puede también estar constituido 
por una expresión alfanumérica o mate- 
mática; ésta se verá resuelta por el orde- 
nador antes de proceder a la presentación 
del resultado en pantalla. 



10 LET A=5 

20 PRINT "SUMA" 

30 PRINT 10+20 

40 PRINT 15-A+2 

50 END 

RUN 

SUMA 
30 

12 



SEPARADORES EN EL 
ARGUMENTO^D EJBBiNT 



UpaiXLLS_ ma instrucción PRINT puede Utili- 
ZargQ para trasladar a la pantajla jjiyp^ns 

datos. Estos deben incluirse dentro de la 
zona de argumento, convenientemente 
separados. Habitualmente, l os signos que 
a dmite cualquier intérpret6 _BASl£_P_a ra 
s eparar a los distintos datosjaue acompa- 
ñan a] pnmanHn PRjNTsnn lacoma ( P ) y el 

pjujíQ- ^coTOa (;). 

Al utilizar la coma como signo de separa- 
ción, los datos aparecerán en la pantalla 
distribuidos en campos de una determi- 
nada longitud. Por el contrario, cuando el 



¿Cómo hay que hablar de un ordenador? ¿Es 
posible establecer una comunicación sin 
recurrir al código máquina?.. El BASIC 
constituye un claro ejemplo cíe lenguaje de 
alto nivel capar, de diluir la distancia entre el 
usuario y la máquina. 
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TABLA DE CONVERSION 


ORDENADOR 


PRINT 






PDIPJT 

rrflH 1 p 


PRINT; 


PRINT "<Mmis.>" 


PRINT X 


PRINT <exp.> 


rnlni l ^-cafBcier 
de control > 


VPLE II 


PRINT 


PRINT, 


PRINT; 


PRINT J <Mens,>" 


DDI MT V 


r n 1 N l e xp . - 




tffBCOT 


PRINT 


PRINT, 


PRINT; 


PRINT <Mens > 




PRIMT í-"ei¥n > 




-"4RI 


PRINT 


PRINT, 


PRINT; 


PRINT <Men$.> 


rnINI a 


PBIMT ovn "> 
rPílN 1 -■ 5Xp. -- 


PRINT <carácter 

rio rnntrrtl^s 


3M 64 


PFINT 


PRINT, 


PRINT; 


PRINT "<Mens>" 


PRINT X 


PRINT <exp > 


PH 1 MT ^ a ra rt f r 
rPíMiJ ii --- ca ra u tu r 

de control > 


3RAGON 


PRINT 


PRINT, 


PRINT; 


PRINT "<Mens. >" 


PRINT X 


PRINT <exp > 


— ■ , 


31UIPOS MSX 


PRINT 


PRINT, 


PRINT; 


PRINT r '<Mens >" 


PRINT X 


PRINT <exp> 




-F-150 


PRINT 


PRINT, 


PRINT[:] 


PRINT "<Mens,>" 


PRINT X 


PRINT <exp.> 




BM PC 


PRINT 


PRINT, 


PRINT; 


■ 

PRINT "<Mens >" 


PRINT X 


\ 

PRINT <exp> 


\ 1 


|VF 


PRINT 


PRINT, 


PRINT; 


PRINT "<Mens.>" 


PRINT X 


PRINT <exp> 




NCR DN-V 


PRINT 


PRINT, 


PRINT; 


PRINT "<Mens>" 


PRINT X 


PRINT <exp> 




SEW BRAIN 


PRINT 


PRINT, 


PRINT; 


PRINT "<Mens >" 


PRINT X 


PRINT <exp.> 




□filC 


PRINT 


PRINT, 


PRINT; 


PRINT "<Mens.> J 


PRINT X 


PRINT <exp.> 




3L 


PRINT 


PRINT, 


PRINT; 


PRINT - Mens.V 


PRINT X 


PRINT <exp.> 




SHARP MZ-700 


PRINT 


PRINT, 


PRINT; 


PRINT "<Mens,>* 


PRINT X 


PRINT <exp > 


PRINT < carácter 
de control> 


SPECTRAV1DEO 


PRINT 


PRINT, 


PRINT; 


PRINT "<Mens.>' 


PRINT X 


PRINT <exp > 




SPECTRUM 


PRINT 


PRINT, 


PRINT; 


PRINT "<Mens>' 


| PRINT X 


PRINT <exp> 





p<Mens.> JJ : Mensaje o texto, entre comillas. <Exp.>: Expresión con dato o datos numéricos o alfanumérícos. 
RDfíMULACIONES DEL COMANDO PRINT 

— \T: Salto a la próxima línea dejando una en blanco. PRINT,: Coloca el cursor unos espacios más adelanta. PRINT; : Deja el cursor en el punto de impresión, sin desplazarlo. 
= \" "<mensa(es> ,J : Escritura en pantalla del mensaje encerrado entre comillas. PRINT X: Escritura en pantalla del valor asignado a la variable X. PRINT {expresión}: 
—en me el valor de la expresión. PRINT < carácter de control>: Ejecuta la acción ordenada por el carácter de controf. 



parador es el punto y coma, los datos 
r imprimirán uno inmediatamente a con- 
"jación de otro. Por ejemplo: 



10 PRINT iJ D0S:\2 
20 PRINT TRES:";3 
30 END 
RUN 

DOS: 2 
TRES:3 





-£* encontrar la coma, el ordenador escri- 
d~ ambos datos dejando un determinado 
^soacío en blanco; éste será mayor o me- 
ict dependiendo de las características de 
zaGa intérprete BASIC. La distribución de 
campos o zonas de impresión dentro de 



una misma línea, originada por la presen- 
cia de este signo separador, resulta muy 
útil a la hora de construir tablas. Hay que 



tener en cuenta al respecto, que la distri- 
bución de los campos se mantiene en 
todas las líneas de la pantalla. 
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TABLA 


DE \JMERGS 






2 


3 


L 


5 


6 


L 


9 


16 


25 


36 


8 


27 


64 


125 


216 


■ 











Glosario 

LENGUAJE MAQUINA: Repertorio de 
instrucciones en código binario 
d i reclame nte inte rp reta bles po r el 
ordenador. 

PROGRAMA FUENTE: Programa escrito 
por el usuario en un lenguaje de 
programación distinto del código máquina, 

PROGRAMA OBJETO: Programa 
resultante de la traducción del programa 
fuente a código máquina. 

INSTRUCCION: Orden elemental que 
comunica una acción al ordenador. La 
instrucción suele constar de dos zonas: 
comando y argumento. E| comando define 
la acción, mientras que el argumento 
aporta los datos sobre los que hay que 
realizarla. 

RETORNO DE CARRO: Orden de salto al 
principio de fa próxima línea. Esta acción 
habitual en las máquinas de escribir es 
trasladable al ámbito de la programación 
BASIC. En este caso, fa función de 
retorno está asociada a una acción sobre 
la tecla RETURN. 

CADENA DE CARACTERES: Secuencia 
de caracteres aifanuméricos fJetras, cifras 
y símbolos} que conforman una unidad de 
información tratable directamente por el 
Ordenador. 

EJECUCION: Puesta en práctica de fas 
órdenes expresadas por medio de las 
instrucciones de un programa. 

ARCHIVO: Conjunto organizado de datos 
residente en una unidad para el 
almacenamiento de información asociada 
al ordenador. 

MODO COMANDO: Modo de 
funcionamiento interactivo, en el cual se 
pueden introducir comandos y ejecutarlos 
a continuación, o bien escribir un 
programa. 



10 PRINT "TABLA DE NUMEROS" 
20 PRINT 2,3,4,5,6 
30 PRINT 4,9,16,25,36 
40 PRINT 8,27,64,125,276 
50 END 

Tal como se observa ai ejecutar el programa 
adjunto, al emplear la coma {,) como 
separador de los datos de PRINT, la pantalla 
se divide en ¡ni determinado n limero de 
campos O zonas de impresión fei mi mero de 
campos y su longitud dependen de cada 
i a t érp reí e BASIC}. 

Los mencionados separadores («coma» y 
«punto y coma») también pueden utili- 
zarse, con el mismo efecto, al final de la 
instrucción PRINT. En ambos casos, el 
cursor que señala el punto de impresión 
pasará a ocupar la posición que corres- 
ponda al separador utilizado antes de im- 
primir el argumento de la próxima instruc- 
ción PRINT. Veamos un programa clara- 
mente ilustrativo de ambas posibilidades: 

10 PRINT "NUMEROS" 

15 PRINT 

20 PRINT 1,2, 

30 PRINT 3 

40 PRINT 4;5;6; 

50 PRINT 7;8;9 

60 END 

Y éste es el resultado de su ejecución: 



RUN 

NUMEROS 

1 2 

456789 



En efecto, la presencia de la coma af final 
de la instrucción 20 desactiva ef salto a la 
próxima .hea de pantalla, de tal forma que 
el .via|p.C> 'aportado por la siguiente íns- 
tn icISh j¿HINT, aparece en el próximo 
Cr i ¡£ g'rtS la misma línea. 
E t r m y coma que cierra la instrucción 
40 nbién inhibe el salto a la próxima 
línea, si bien, en este caso, el próximo 
dato (7) se visualizará adosado al último 
dato que figura en el argumento de la 
instrucción 40. 

La instrucción 15 del ejemplo anterior ilus- 
tra otra de las peculiaridades def PRINT. 
Una instrucción PRINT puede estar cons- 
tituida exclusivamente por el comando, 
desprovisto de argumento alguno. Su eje- 
cución hará que aparezca en fa pantalla 
una línea en blanco, pasando el cursor a 
ocupar la próxima línea de impresión. 




Son muy diversos los dialectos BASIC que coexisten en la actualidad. La mayor parte de los 
fabricantes incluyen en sus equipos un intérprete BASIC con ciertas peculiaridades en su 
vocabulario v sintaxis. 
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Loga (i) 



El lenguaje de la escuela 




L lenguaje LOGO fue desarro- 
llado por Seymour Papert en el 
Laboratorio de Intel^en a : Ar- 
tificial del MJT, (!'/j335 iC;¡U- 
ggvs ínstitute of Technology). \ ^pb< tyku 
: ñuscaban un sistema que ■" -> m \ ara 
, o para la enseñanza del uso . las 
—^adores. Tras varios meses de íhves- 
TOran, surgió el LOGO: un lenguaje mo- 
: nacido bajo la inspiración del LíSP. 
E ¡2 último es un lenguaje evolucionado, 
=-:ado a aplicaciones de inteligencia ar- 

■ ? que en "1959 vio la luz desde los 
: 3s laboratorios del M.I.T, 

rases conceptuales def LOGO son la 
- ' : tZ jn : da a la potencia de operación. 

■ e características fundamentales del 
I J se concretan en su naturaleza de 
: .-. ;e modular e interactivo. La modu- 

se refleja en el hecho de que e! 
«jano del LOGO va creando pequeños 
■ - :_ :s independientes que, a su vez, 
*sn de piezas para construir estructu- 
. "^és complejas. El LOGO es un len- 

■ - interactivo en el sentido de que 
:j:er orden es procesada de inme- 
: con só lo introduciría en el orde- 

"-: a sus orígenes, inspirados en un 
.aje para el tratamiento de listas de 
: —el LISP (LISt Processor)— f uno de 
. _~:os fuertes del LOGO reside en la 
-¿--colación de listas, affanumé ricas. No 
~~^^:e r su característica, más especta- 
r_¿~ "ay que buscarla en el tratamiento 
'aficos, tarea encomendada al sis- 
i denominado TURTLE GRAPHICS. 
t secutar TURTLE GRAPHICS (gráficos 
- _ : : ? por medio de la tortuga),, es un 
- - : : : fácil y divertido para la confección 
: oujos. El concepto de tortuga pro- 
- ::e ciertos robots desarrollados a 
: := de 1960. Estas máquinas con- 
-.- en un caparazón flanqueado por 
• de ahi el nombre de tortuga) y 
%sronaban asociadas a un ordenador. El 
■arador guiaba a la tortuga y ésta iba 




La popular «tortuga» es el nimbólo del 
lengua j£LO.GúrÍste~ simpático personaje es 
el protagonista del «Tur t le Graphics»; un 
método sencillo y divertido para la creación y 
tratamiento de di bajos. 




La filosofía de programación del LOGO se 
fundamenta en los denominados 
«procedim ie n tos » . La pote ncia de este 
lenguaje brota de la posibilidad de construir 
programas evolutivos, integrando 
procedimientos ya definidos dentro de otros 
más complejos. 



dejando marcada la huella de su trayecto- 
ha en el suelo, 

A principios de 1970 surgió la variante 
actual de tan simpático y útil personaje: la 
tortuga que evoluciona sobre la pantalla. 
La idea de guiar a una tortuga a través de 
la pantalla de visualizados ha sido adop- 
tada por otros muchos lenguajes para re- 
solver el aspecto de creación de presenta- 
ciones gráficas. Junto a las posibilidades 
gráficas, el LOGO aporta un potente len- 
guaje de programación de tareas, fácil de 
aprender y edificado a partir de un vocabu- 
lario y unas estructuras simples y versa- 
tiles. 

La sencillez inherente al empleo del 
LOGO, han convertido a este lenguaje en 
idóneo para labores pedagógicas y de ini- 
ciación a la programación de ordenadores. 
Los seguidores del LOGO declaran que se 
trata de «un lenguaje para aprender»; afir- 
mación no sólo aplicable a aprender a pro- 
gramar, sino también extensiva a apren- 
der a discurrir en base a estructuras ló- 
gicas. 

En efecto, el LOGO es algo más que un 
lenguaje de programación; hay que con- 
cebirlo como un verdadero entornojja raja 
e nseña nza a sis tida por orde nado r. Con 
este lenguaje, los niños aprenden a traba- 
jar con ordenadores como si se tratara de 
un simple juego. El secreto reside en -la 
naturaleza interactiva dendiálogo, que faci- 
lita la creación y depuración de estructu- 
ras por el sistema de prueba-error. 
Existen en el mercado distintas versiones 
de LOGO. La mayor parte, desarrolladas 
por fabricantes de ordenadores en colabo- 
ración con el Grupo Logo del M.I.T. (TI 
Logo, Apple Logo, Atarí Logo, etc.). Se 
diferencian en muy poco, concretamente 
en abreviaturas de palabras LOGO, en la 
inclusión del TURTLE GRAPHICS y en el 
tratamiento de listas. También cabe men- 
cionar la existencia de una versión en cas- 
tellano del TI Logo [versión de Texas Ins- 
truments). 
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Glosario 

INTELIGENCIA ARTIFICIAL: rama de la 
ciencia que investiga la simulación de una 
auténtica inteligencia en un ordenador. 

DEPURACION: fase del desarrollo de un 
programa consistente enlabúsquedade 
los fallos cometidos al codificarlo o 
escribirlo, 

PROCEDIMIENTOS: subprogramas que 
forman parte de un programa mayor o 
«principal». 

MEMORIA CENTRAL: zona para el 
almacenamiento de información residente 
en eí interior del ordenador y a disposición 
directa de la unidad central de proceso. En 
elEa se almacenan datos, variables y el 
programa o programas en curso. 



LA FILOSOFIA DEL LOGO 



La programación en LOGO se funda- 
menta en el empleo de procedimientos 
definidos por el usuario. Estos procedi- 
mientos son conjuntos de órdenes a los 
que se accede como si se tratara, real- 
mente, de una orden única. A su vez, las 



Aspecto de un procedimiento LOGO, o 
conjunto de instrucciones ai que se accede a 
través de una orden única. 




Traductores de lenguajes 



La comunicación entre dos personas que 
hablan distinto idioma no puede 
establecerse sin la colaboración de un 
traductor. Este puede ser un intérprete 
que realice una traducción simultánea, 
frase a frase: O simplemente un traductor 
que escriba en el idioma del destinatario 
el texto redactado en e\ idioma de origen. 
Esta es una realidad trasladable al mundo 
de los ordenadores. Excepto en el caso 
de que el diálogo se mantenga utilizando 
el lenguaje máquina, es necesario un 
proceso de traducción para que el 
programa confeccionado por el usuario 
sea inteligible para el ordenador. Por 
supuesto, la tarea de traducción no 
correrá a cargo de traductores humanos; 
de ello se ocuparán los ordenadores una 
vez «instruidos» al efecto 

Ep CU alqjJ'^r pmrp^A_rie_t rari i j mán 
i nte ryienen, dos r^o^rarn as : 

• El programa fuente, redactado en un 
lenguaje evolucionado, ensamblador o de 
alto nivel, 

• El pro^rama_gbj^to o programa 
resultante del proceso de traducción, 
escrito en el lenguaje propio de la 
máquina. 

Tal como ocurría en la traducción de 
comunicaciones humanas, también en 
este caso cabe una doble posibilidad: 
recurrir a un intérprete o traductor 
simultáneo, que permitirá un diálogo ó 
comunicación interactiva, o utilizar los 
servicios de un traductor que reescriba el 
contenido de la comunicación en el 



lenguaje del destinatario (la máquina en 
nuestro caso). 

Los eficientes traductores humanos serán 
ahora programas auxiliares especializados 
en tal menester. Y, de nuevo, 
especializados en realizar una traducción 
interactiva o demorada (del mensaje en 
bloque). 

Los intérpretes son los programas 
especializados en la traducción interactiva. 



- r -tC3RAMA 




La comunicación entre dos personas que 
hablan distinto idioma no es posible sin la 
Intervención de un traductor. Algo 
semejante ocurre a la hora de dialogar 
con las máquinas. Es preciso contar con 
un traductor que convierta al lenguaje 
intimo de la máquina ¡as órdenes y 
mensajes formulados por el usuario en un 
lenguaje de alto nivel. 



Traducen el programa línea a línea, de tal 
forma que el ordenador las ejecuta a 
medida que va disponiendo del resultado 
de la traducción. 

La traducción diferida corre a cargo de los 
denominados programas compiladores. 
Estos traducen el programa fuente en 
bloque, obteniendo el correspondiente 
programa objeto redactado en el lenguaje 
de la máquina que debe ejecutarlo. 
De la realidad humana podemos extraer 
otras conclusiones aplicables a los 
programas intérpretes y compiladores. En 
principio, la utilidad del intérprete se 
manifiesta en los diálogos interactivos; de 
ahí que este tipo de traductor resulte 
idóneo cuando se trata de habilitar una 
comunicación inmediata con la máquina. 
Otro factor significativo es que, dado el 
método de traducción, el intérprete 
invertirá bastante más tiempo en realizar 
su función que un compilador. Este último 
realiza la traducción del programa en 
bloque, de una sola vez, sin aguardar a 
que vayan ejecutándose las instrucciones 
a medida que son traducidas. La 
característica de velocidad se inclina, 
pues, hacia los compiladores. Este es un 
dato extensivo al proceso de ejecución : la 
ejecución del programa objeto, traducido 
en su integridad {compilado), es mucho 
más rápida que ta ejecución línea a línea 
del programa interpretado (de tres a 
veinte veces más rápida}. 
La interpretación de un programa fuente 
se efectúa en el propio ordenador que 
cursará su ejecución. Sin embargo, el 
compilado de un programa puede no 
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Lenguajes 




-enes están constituidas por cadenas 
ra datos, operadores y comandos. La po- 
nencia del LOGO brota de la posibilidad de 
-ti liza r procedimientos dentro de otros 
i'ocedimientos. Semejante característica, 
rermíte programar potentes operaciones 
zsrtiendo de unidades elementales. El 
~étodo a seguir consiste, sencil Jámente, 
en construir ios procedimientos com píe- 
es a partir de la asociación de otros proce- 
: cientos más simples definidos con an- 
ferioridad, 

5~ realidad, el LOGO carece def concepto 



ras el BASIC, el LOGO es el lenguaje más 
:pu lar izado en el terreno de ¡os equipos 
om esticos. Son muchos ios ordenadores 
monales de esta categoría que disponen de 
I intérprete de lenguaje LOGO, 




realizarse en el ordenador que debe 
ejecutar el programa objeto. Es frecuente 
que sea un ordenador auxiliar el que se 
encargue de generar el programa objeto, 
redactándolo en el lenguaje máquina 
propio del equipo al que vaya destinado. 
Terminada la compilación, el programa 
puede ya introducirse y ejecutarse 
cuantas veces sea necesario en el 
ordenador de destino 
Son muchos los fenguajes para ios que se 
dispone de ambos tipos de traductores. 



La elección de intérprete o compilador 
dependerá del tipo de actividad que se 
encomiende al ordenador. Si la velocidad 
no es un factor primordial y prima la 
necesidad de mantener un diálogo 
interactivo, habrá que optar por un 
intérprete. Los microordenadores 
domésticos incorporan de origen un 
intérprete de lenguaje BASIC; si bien, el 
fabricante suele disponer de un catálogo 
de intérpretes y compiladores, en opción, 
de otros lenguajes. 



Cuando la característica solicitada es una 
alta vefocidad de ejecución, no cabe duda 
en la elección: hay que optar por un 
compilador. 

Los lenguajes con una marcada inclinación 
hacia las aplicaciones interactivas (BASIC. 
LOGO, PILOT...) suelen utilizarse en 
versión compilada; mientras que los 
lenguajes más especializados, 
habitualmente no interactivos (FORTRAN, 
COBOL ALGOL PL/3...) actúan a través 
de compiladores. 



INTERPRETE DE LENGUAJE 
PROGRAMA EN EJECUCION 



I | COMPILADOR DE LENGUAJE 
H! PROCESO DE COMPILACION 



INTERPRETE 



PROGRAMA 
FUENTE 




La actividad del traductor puede 
manifestarse realizando una Traducción 
simultánea del diálogo, o efectuando la 
traducción del mensaje total, de una sola 
vez. Los programas Traductores del 
primer tipo son los denominados 
■intérpretes» y los del segundo 
í compiladores » . 



COMPILADOR 



PROGRAMA 
-UENTE 
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El nacimiento del LOCO tuvo su fuente de inspiración en el USP. un lenguaje ^«^omdef 
TríenZdo a aplicaciones de inteligencia artificial. Dado su origen y sus propias caracteusmas. 
el LOGO es un lenguaje que resulta adecuado en el marco tte ia rabonea. 



de programa como tal r lo que se suple con 
el denominado «WORK SPACE» o espa- 
do de trabajo. Este contiene los procedi- 
mientos y vahantes definidos por el usua- 
rio; y, por supuesto, en él existirá, gene- 



ralmente, un superprocedimiento, o pro- 
cedimiento principal, que hace uso de 
otros subprocedimientos. 
En un mismo espacio de trabajo pueden 
coexistir varios superprocedimientos in- 



dependientes. Esto equivale a tener \b- 
rios «programas» independientes en 
memoria central. 
Como ya se ha indicado, el LOGO es un 
lenguaje fundamentalmente interactK - 
Los mensajes de error son claros y conc- 
sos. Por ejemplo, si a través del teclado se 
introduce la palabra "HOLA 11 , seguida efe 
una acción sobre la tecla RETURN (la c 
den para que el ordenador asimile el me^ 
saje introducido), la máquina responder- 
con un significativo: 
I DONT KNOW HOW TO HOLA 
(¡Ignoro cómo realizar la acción HÓLA!) 
Con este mensaje, el LOGO comunica ai 
usuario que el procedimiento HOLA r: 
está definido en el espacio de trabajo. Sí e* 
error deriva de la omisión de un dato de 
entrada dentro de una orden, el LOGO 
responderá esta vez con : 
NOT ENOUGHT IWPUTS TO XXX 
t¡ No hay suficientes datos de entrada pa 
cursar la orden XXX!) 
Otra capacidad notable del LOGO se ma- 
nifiesta en el tratamiento de cadenas alfa- 
numéricas. Sus potentes instrucciones 
permiten añadir, extraer y comparar ele- 
mentos inmersos en las mismas sin nin-j 
guna dificultad. 



Programación y ejecución 





PROGRAMACION 



EJECUCION 



Los lenguajes informáticos comparten el 
mismo objetivo que los humanos; ofrecer 
el medio adecuado para que pueda 
establecerse una comunicación. En el caso 
de la máquina, la comunicación se 
concreta en «instruirla» para que ésta 
desarrolle un trabajo o realice una tarea 
específica. Aquí es donde aparece el 
concepto de programa «o secuencia 
ordenada de instrucciones », cuya puesta 
en práctica o ejecución 
resuelve un calculo, efectúa un tratamiento 
de información o r en general realiza la 
tarea detallada en el programa. 
En definitiva, programar al ordenador 
equivale a confeccionar la secuencia de 
instrucciones o programa, utilizando un 
lenguaje apropiado, inteligible para el 
ordenador. 

Cuando la máquina deba efectuar el 
conjunto de operaciones o tarea 
programada, es preciso que el usuario 
introduzca el programa en la memoria del 
ordenador. A partir de ese instante, éste 
puede ordenar su ejecución. Ejecución que 
realizará el ordenador examinando las 
sucesivas instrucciones que componen el 
programa, interpretando su significado y 
cursando las órdenes y operaciones 
encomendadas. 



s.o. 




Los S.Os. de la microinformática 



Del nacimiento del microprocesador 
a los modernos sistemas operativos 



L desarrollo de los sistemas 
operativos ha seguido un ca- 
mino paralelo al de la evolu- 
ción de los ordenadores. Es 
'dente, pues H que al nacer el micropro- 
cesador y, en torno a éste, desarrollarse 
: io el universo microinformático, iba a 
manifestarse una evolución semejante en 
^ terreno de los sistemas operativos. 
..i albores de la microinformática, repre- 
guntados por los primeros modefos de fas 
-mas americanas Apple Computers y Ra- 
: Shack, o por el alabado PETde la tam- 
sén americana Commodore, no tuvieron 
f impacto inmediato en el terreno de fos 

- 5. 

WgtgngL^ n o disp o- 

"ende un sistema operativo organizado y 
" entidad propia. Todos ellos incluían un 
---Jeto y primitivo repertorio de funcio- 
t5 básicas para el control de la máquina, 
degrado dentro del traductor de lenguaje 
=¿S1C 

:e método aún está presente en cier- 
:í ordenadores domésticos (ZX-81, 
- : -3PECTRUM, ORIC). El intérprete del 
aguaje BASIC incorpora algunas funcio- 

- elementales propias de cualquier sis- 
l^ia operativo; por ejemplo, destinadas 
I 5 :ontroí de los periféricos asociados al 

. po: pantalla de visuaíización, graba- 
cr 'eproductor de casetes... 
ps como ocurre en los ordenadores per- 
cales menos evolucionados, los prime- 
tes microordenadores encerraban una to- 
I s exclusividad en cuanto al uso de pro- 
cas. Toda fa estructura de programa- 
dependía del propio intérprete, que 
itlo ejercía la tarea de traductor sino 
también gobernaba los recursos del 
'/are. 

- - t método de explotación hace fmposi- 

- = confección de programas utifizables 
:i s tintas máquina s; puesto que la 

pnpatibilidad de los programas sófo será 
i — :uando las máquinas compartan, ade- 



más del intérprete, toda la estructura cir- 
cuital controlada por el mismo. 



NACIMIENTOi)EL_CP/M 



Esta deficiencia incitó a algunos expertos 
a lanzarse en busca de un sistema opera- 
tivo para los nuevos equipos, pioneros de 
la microinformática. Era preciso desarro- 
llar un sistema operativo capaz de actuar 
com o puente entre el_hardware de distin- 
tas má quinas y e l traductor de leng uaje; 
de lograrlo podía avanzarse en la tan anhe- 
lada senda de la estandarización. 
De ahí n ació el CP/Tvl (Control Program for 
Microprocessors: programa de c ontrol 
para microp rocesador es}, de manos de la 
compañía americana Digital Research 
Tras éste fueron brotando el Apple. Dos y 
otros tantos sistemas operativos, casi to- 



dos ellos con una denominación termi- 
nada con las siglas DOS (Disc Operating 
System: sistema operativo en discoj. 
Durante algunos años, el CP/M fue el sis- 
tema operativo casi exclusivo en el campo 
de los microprocesadores. En 1973, la 
firma Intel anunció el desarrollo del primer 
microprocesador con potencia suficiente 
como para constituir la unidad central de 
proceso de un microordenador. A partir de 
ese instante, Gary Kildall empezó a conce- 
bir las primeras versiones de lo que, més 
adelante, se convertiría en el popular 
CP/Tvl. Un sistema operativo en plena vi- 
gencia y que, en la actualidad, puede en- 
contrarse en cerca de un millón de ce- 
nadores 

ATñácer el CP/M r los fabricantes se en- 
contraron ante la alternativa de acogerse 
al mismo, o crear un sistema operativo 
exclusivo para su microordenador Las 
contrapartidas eran obvias: el uso del 
CP/M abría las puertas para que su equipo 
pudiera utilizar cualquier programa adap- 
tado a este sistema operativo 





s.o. 



La cada vez mayor aceptación del CP/M, 
revirtió en el nacimiento de una biblioteca 
de programas que podían ejecutarse en 
distintos microordenadores. Poco a poco , 
el repertor tQ_de programas fuejncrerpen- 
tándo se con las ap ortaciones de los fabri- 

c antes x gQ3PJg^^^g^ r ^ m ^Í^ ^ ue 
adoptaron el nuevo estándar AsLaS-Como 
e l CP/M se convirtió en el líder i ndiscu t i- 
b ie _de. los sistemas operativ as, en la es- 
casa década de vida de la microinformá- 
tica, 



DEL MICROPROCESADOR AL S.O. 



5i_el mic roprocesadore s e| cerebro ínte- 
g rado que ha permitido eljiadmientolde 
los microgj]denadares r parece obvio que 

MICROPROCESADOR 




SISTEMA 
OPERATIVO 



Su relación con la inri mi dad de fa máquina 
llega hasta tai punto que los sistemas 
operativos están diseñados para un 
determinado tipo de mic roprocesador. 

tú 

también será éste el responsable de la 
trayectoria microinformática de los siste- 
mas operativos. 

Una de las funciones primordiales del sis- 
tema operativo es la de actuar de puente 
entre el hardware de la máquina y los 
programas de aplicación. En consecuen- 
cia, el sistema operativo tiene que estar 



concebi do en perfec ta_ consonancia con el 
nnicroprocesadcirrCada sistema operativo 
está destinado a un determinado tipo de 
microprocesador, o a una familia de mi- 
croprocesadores que comparten unas ca- 
racterísticas comunes. Así, por ejemplo, 
el sistema operativo ProDOS está desti- 
nado al microprocesador 6502, mientras 
que el MS/DOS está creado para coexistir 
con el microprocesador 8038. 
Encesta primera déc ada d e_1a_ microinf or- 
máti ca, la época~de los micr oprocesado- 
reTjje jbrts, el lid e razgo ha__coxr£gpon- 
dido a ljsist ema operativo CP/Tvl^ Una_de 
las bjzas"q üe^más h aoojitr ibuido a la pro- 
yeccjcS^^ 
fannilíajii^^ 

esjáj^inaj±>:WJ8~8ü8Ü75u^^ 
Hay que tener en cuenta que los princi- 
pios del CP/M están ligados al propio naci- 
miento del microprocesador. La firma 
americana Intel — uno de cuyos técnicos 



8080. Esta línea tuvo su posterior con - 
nuidad en el 8085 y llegó al pleno domine 
del mercado con el Ziíog Z-80: un mic r z- 
procesador que r aun sin salir de las manos 
de Intel perpetuaba la filosofía de los prc- 
ductos de esta firma en el terreno de los 
microprocesadores de 8 bits. 
El predominio de esta familia de micropro- 
cesadores de 8 bits, constituye una razór 
de verdadero peso para justificar el al- 
cance que ha logrado el sistema operativo 
CP/M. 

S.Os. PARA MICROPROCESADORES 
DE 8 BUS 



El absoluto protagonismo del CP/Tvl, en- 
sombrece a otros sistemas operativos 




Apple DOS 



UCSD p-system 



PICK 



OASIS 







MONOUSUARIO 


| 1 16 BITS 




MULTI USUARIO 



Características básicas de los sistemas 
operativos más importantes en el terreno 
de la microinformática. 



fue, precisamente el creador del CP/TVL 
Gary Kildall— fue quien puso en el mer- 
cado el primer microprocesador. Un 
avance que se consumó con el lanza- 
miento del primer microprocesador de 8 
bits, el 8008, y con el desarrollo del primer 
microprocesador capaz de constituir el ce- 
rebro de un microordenador: el Intel 



cuya potencia es, en algunos casos, ple- 
namente equiparable a la del líder. Entre 
éstos se encuentran el OASIS, Apple. 
DOS, PICK, FLEX, TURBODOS, ProDOS y 
UCSD p-System 
Con et empuje de los microordenadores 
de 8 bits, han ido apareciendo nuevas ver- 
siones, cada vez más actualizadas, dei 
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£1 microprocesador es el cerebro integrado 
Jtte ha permitido el nacimiento de la 
micro inform ática . Un protagonismo que lo 
Convierte en el responsable de la evolución 
ée los modernos sistemas operativos. 



~ 3 /M-80. La más utilizada en la actualidad 
es la revisión 2.2 (CP/M 2,2). 
: 53ientemente p ha aparecido un nuevo 
i =:ema operativo que promete alcanzar 
implantación sustantiva en el terreno 
36 los microprocesadores de 8 bits. Este 
es el denominado MSX.DOS, de la com- 
pañía americana Microsoft. Además de 
-E-star destinado a un microprocesador 
impartido por el CP/M r el Z-80, el 
VSX.DOS presenta una cierta compatibili- 
dad con el protagonista; por ejemplo, 
:_ede utilizar archivos creados a partir del 
BVM. 

E objetivo del MSX,DOS se sitúa en los 
llenadores personales de tipo familiar, 
"instituye uno de los elementos que 
:~nfiguran la norma MSX, a la que se han 
adscrito más de una docena de fabrican- 
as japoneses y algún europeo, 
~-as los microprocesadores de 8 bits, lie- 
3= r on los microprocesadores capaces de 
xerar internamente con palabras binarias 
3e 1 6 bits. Actualmente, existen ya micro- 
: pesadores de 32 bits. La evolución de 
:s ordenadores personales ha seguido 
sor completo fa fínea trazada por los mi- 
:~orocesadores, Hasta tal punto que la 
~ayor parte de los equipos profesionales 
* de gestión incorporan un microprocesa- 

de este tipo. 
,:s 8 bits han quedado relegados casi por 
repleto al terreno de los ordenadores 
xm esticos, con un acentuado dominio 
microprocesador Z-80 r seguido a dis- 
ocia por el 6502 y, tras éste, el 6809. 



& SALTO A LOS 16 BITS 



i derazgo del CP/M se diluye en el 
~3*co de los microordenadores de 16 
rs, La irrupción de ía multinacional IBM 
■t el mundo def ordenador personal, su- 
tso el vertiginoso ascenso de un nuevo 
ístema operativo que supera en este ám- 
r.z al CP/M. Se trata del MS/DOS, 
rsado por la firma americana Microsoft. 
: VS/DOS, rebautizado en los ordenado- 




De máquina 
a ordenador 

El primer contacto con la idea de ordenador 
suele derivar de la observación de una 
máquina que, con rapidez y eficacia, 
confecciona la nómina de la empresa en la 
que trabajamos o que, sencillamente, llena 
los ratos de ocio con emocionantes juegos 
en la pantalla del televisor, 
Para llegar a este nivel de funcionalidad, 
hay que equipar al hardware o arquitectura 
física de Ja máquina con un surtido de 
vituallas que lo irán convirtrendo en la eficaz 
herramienta que gestiona una aplicación. El 
trayecto de máquina inerte a ordenador 
pasa por tres etapas básicas: 

a) Incorporación del sisteme operativo. 

b) Con la máquina dotada de una 
inteligencia bás'ca, puece va ce^sa^ss- en 
completarla con un traductor de lenguaje 
que facilite un diálogo más completo y 
directo. 

c) La máquina está ahora en disposición de 
interpretar y ejecutar programas de 
aplicación creados por el usuario o 
programas adquiridos para instruir a la 
máquina en cierta tarea específica. El 
software de aplicación, o paquetes de 
programas que permiten at ordenador 
realizar una tarea específica, suele nacer 
orientado a su complementariedad con el 
sistema operativo, Por ello, en muchos 
casos, puede ocupar directamente la 
segunda planta del edificio informático, 
instalándose sobre el nivel ocupado por el 
sistema operativo. 



| 5 

OPERATIVO 




TRADUCTORES 
DE LENGUAJES 



SOFTWARE 
CE APLICACION 



PROGRAVAi r- 

lencja-e z e:: : . r.; 

POR E_ Z"?~Dy 



35 



s.o. 



res personales IBM como PC/DOS, se ha 
convertido, en muy poco tiempo, en un 
sistema operativo de gran popularidad y 
cuya implantación crece día a día. 
Casi todos los sistemas operativos que 
coexistían en el mercado de los equipos 
de 8 bits, han derivado de nuevas versio- 
nes adaptadas a los microordenadores de 
la nueva generación. Tal es el caso del 



propio CP/Tvl, que ofrece las versiones 
CP/M-86 y Concurrent CP/Tvl, para los mi- 
croprocesadores 8086 y 8088, y el CP/M- 
68 K destinado al microprocesador 68000 
de la firma Motorola. 
Otros sistemas operativos relevantes en 
el campo de los 16 bits son el UNIX, 
OASIS, PICK y UCSD P-system. En otro 
rango están los sistemas operativos que 



crea el propio fabricante para sus equic 
A este grupo pertenece, por ejemplo, 
QL-DOS destinado ai Sinclair QL 



S.Üs. MULTIUSUARI0 

E INTEGRADOS^ 




Los sistemas operativos integrados constituyen la más rec iente innovación en el terreno de ios 
sistemas operativos. Su presencia en ei ordenador aporta una nueva filosofía de trabajo que 
facilita la relación hombre } máquina, 



Otra consecuencia de ja evolución de 
microor denadore s, esJa^posibiJtdad de 1 
baja^aj^imeruto^u^ EJ_ord 
nad or reparte su at ención _e jntre_vark 
usuarios, cu rsando eri_£ ada_caso un 
ceso distinto ; no obstante la velocidad i 
tal que los tiempos de espera son 
insignificantes. 

Los sistemas operativos para microorti 
nadores han entrado en los equipos i 
tiusuario, aportando funciones propias I 
sistemas operativos para miniordenad 
res y grandes equipos. De nuevo, predo-1 
minan en este ámbito algunas versiones I 
de sistemas operativos mono usuario. Por| 
ejemplo, los MP/M-80 y MP/Tvl-86, 
son versiones multiusuario del CP/M de 
tinadas a equipos de 8 y 16 bits, respecr- 
vamente. También cabe destacar al UNI> 
un sistema operativo multiusuario, pan 
1 6 bits, de reconocida potencia. La firn 
Microsoft, que detenta 3a autoría del I 
DOS, también desarrolló su sistema op 
rativo multiusuario, para 16 bits, denomi- 
nado XENIX. E incluso el sistema open 
tivo OASIS se encuentra en versione 
multiusuario para microordenadores de i 
y de 16 bis. 
El último peldaño en los sistemas. opecat- 1 
vó s pB ra m i c roo rd e n a d o re s, lo , oc u pa n. J c s 
sistemas operativos integragjQS. Con j 
s e "di I uy é la" sepa ración entre sistema op 
rativo y software de aplicación. Supon 
un cambio en la filosofía de trabajo de 
ordenadores., ofreciendo al usuario un er- | 
torno multi-tarea caracterizado por-yn 
gran facilidad de control. En este grupo s 
inscriben los sistemas operativos de le 
modelos Lisa y Macintosh de la firma > 
pie Computers, o el sistema operativo ir 
tegrado del ICL Perq, 
La opinión de los expertos vaticina un pro 
metedor futuro para esta nueva gener; 
ción de sistemas operativos, hasta 
punto de que en pocos años, pueden 
gar a sustituir por completo a los S.Os 
tradicionales. 
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En busca del ordenador... 



A través del software 
de aplicación 



E nuevo, hay que partir de la 
constatación de que el rendi- 
miento del ordenador en el te- 
rreno práctico depende, casi 
por completo, de la calidad de los progra- 
nas que lo «instruyan»: del software de 
aplicación. Ante tal realidad, no cabe duda 
de la importancia que tiene elegir el soft- 
ware idóneo para cada aplicación. 

¿COM O ELEGIR EL SOFTWAR E 
DE APLICACION? 



arios son los factores que entran. .en 
^gp_ajajwa jj.e_jeJegiíi£l^Qftiíi¿3re. Fac- 
tores que van desde la evaluación estricta 
3e la tarea a resolver hasta la elección del 
ioporte adecuado en cada caso. Aun 
: jando se prestará una especial atención 
= tema más adelante, es conveniente an- 
tcipar en este punto algunas considera- 
: ones que deben intervenir en la elección 
:el software idóneo. 

'_ . Una definición precisa y detallada de 
3s necesidades. 

Este es el primer paso, ineludible para la 
zorrecta elección. Cuanto más precisa sea 
= definición de las características de la 
"3rea o aplicación que se desea informati- 
13 r f mayor será la garantía de éxito en la 
decisión final. Una exposición detallada y 
: -acta permitirá descartar programas que r 
aun ajustándose algunas de las caracterís- 
tcas solicitadas, omiten la resolución de 
~2^eas que limitan el rendimiento práctico 
oe la aplicación, 

I ¿Software de creación pcopJa T ^B-me- 
; :z» o estandarizado? 
r nivel de conocimientos de programa- 
zn por parte def usuario, la complejidad 
:e ía aplicación y la existencia de paque- 




Lü entrada en el mundo de la informática, deriva, normalmente, de la necesidad de nmr t 
un auxiliar eficiente y capaz de resolrer determinadas tareas. Una vez. decidida ta a¡ 
aplicaciones que hay que automatizar... 




¡fay que comprobar si existe en el mercado de algún programa ajustado a nuestras 
n ecesidades espe c tfi cas . 



Aplicaciones 



SISTEMAS OPERATIVOS 




El siguiente eslabón que conducirá al ordenador idóneo, h constituye la respuesta o un naero 
interrogante: ¿Para qué sistema operativo esto concebido td programa o paquete de aplicación 



seleccionado? 



tes de aplicación estandarizados, son al- 
gunos datos que intervienen en esta deci- 
sión, 

El desarrollo del mercado del software, ha 
llegado a un nivel en el que es posible 
encontrar programas de cualquier tipo y a 
precios moderados; de ahí que, habitual- 
mente, no suela contemplarse la primera 
alternativa. 

Antes de decidirse por encargar un soft- 
ware «a medida», es necesario examinar 
con detalle la oferta de aplicaciones estan- 
darizadas, El precio de estas últimas será 
siempre muy inferior al de una aplicación 
semejante encargada con exclusividad. 



i 

Es 



3j ¿QuéjQQorte^ 
sta es una decisión que dependerá de 



las propias características del ordenador y 
de la naturaleza del programa o del pa- 
quete de aplicación. 

El propietario de un ordenador personal 
de tipo familiar, suele contar con tres posi- 
bles soportes: cásete, cartucho enchufa- 
ble o disco flexible. Los programas desti- 
nados a estos equipos — <le juegos, edu- 
cativos o de gestión personal— suelen 
ofrecerse almacenados en más de un so- 
porte. Siempre que exista tal posibilidad, 
la opción preferible es el cartucho enchu- 
fable. En primer lugar, la velocidad de tra- 
bajo será superior puesto que el pro- 
grama viene almacenado en una memoria 
que pasa a formar parte de la propia es- 
tructura direccionable por el ordenador La 
comodidad también será superior: no hay 



que realizar operaciones de carga o tras- 
vase del programa del soporte a la memo- 
ria interna del equipo. Tan sólo hay un 
dato en contra: el precio del cartucho es 
superior al de la cásete o del disco. 
Las aplicaciones más complejas, científi- 1 
cas, de gestión o administrativas, eluder 
normalmente, cualquier otro soporte dis- 
tinto del disco. 

<3? Compatibilidad con el_ ordenad o^ 
Los programas y paquetes de aplicación 
no son universales, sino que están conce- 
bidos para un determinado equipo, o para 
su compatibilidad con un sistema opera- 
tivo específico. 

Una misma aplicación puede ofertarse er 
distintas versiones. Por ejemplo, la popu- 
lar hoja electrónica «Visicalc» está dispo- 
nible para distintos equipos familiares y 
para varios sistemas operativos habituales 
en el campo de los ordenadores persona- 
les más evolucionados (CP/ívl, MS/DOS 
OASIS...), 

Á la hora de elegir el paquete adecuado 
habrá que verificar su total compatibilidac 
con el ordenador destinatario, tanto por le 
que respecta al sistema operativo como c 
soporte en el que se entrega. El disco 
flexible que almacena el paquete de apli- 
cación, debe ser compatible con la unidac 
de disco asociada a nuestro ordenador. 



n factor muy importante es la amplitud, 
detalle y tratamiento de la documentación 
que acompaña a la aplicación. No hay qu 
perder de vista que el usuario debe fam' 
lia rizarse con la aplicación a través del m~ 
nual. 

Excepto en el caso de los programas de 
juego, que no precisan de excesivos co- 
mentarios, el manual debe ser completo, 
detallado y redactado en un idioma qus 
domine el usuario. Este llegará a extrae' 
un rendimiento idóneo en la medida en 
que aprenda a utilizar la aplicación y co- 
nozca todas y cada una de las posibilida- 
des que le brinda. 
También es conveniente que la documen- 
tación incluya una relación de posibles f 
líos, incluso debidos a omisiones del pr 
pío usuario no experimentado, con u 
claro detalle de las soluciones en ca 
caso. 

Cada día son más las aplicaciones qu 
sustituyen la amplitud del manual escrít 
por un programa de aprendizaje, de ti 
tutorial. Esta es una opción cómoda 
apreciable. 
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Aplicaciones 



El ordenador personal: una gran familia 



La actividad del ordenador personal se 
manifiesta en aplicaciones que van desde la 
simple generación de un juego en la 
pantalla del televisor, hasta la gestión 
completa de fas tareas administrativas de 
una pequeña o mediana empresa, 
Adoptando criterios exclusivamente 
prácticos, como puede ser el volumen y la 
potencia de trabajo, cabe establecer una 
clasificación dentro del mundo de los 
ordenadores personales. Una clasificación 



plagada de intersecciones entre los 
diversos grupos, y que permanece abierta, 
a tenor de la constante evolución de estas 
máquinas y a la proliferación de modelos de 
casi cualquier volumen y posibilidades: 

• Ordenadores de bolsillo 

• Ordenadores domésticos 

• Ordenadores portátiles 

• Ordenadores profesionales 

• Ordenadores de gestión 



El recinto en el que se plasma la actividad 
de estos grupos de ordenadores 
personales es, ni más ni menos, el que 
inspira su denominación. Desde el simple 
ordenador de boisillo {como es el caso del 
ZX-81), hasta el consumado ordenador de 
gestión (Apple Lisa, HP-150, NCR DM-V o 
DEC Professional-300), se encuentra un 
extenso abanico de equipos, más o menos 
potentes y capaces de automatizar las 
tareas más diversas. 





ORDENADORES DE BOLSILLO 



ORDENADORES 
PROFESIONALES 





ORDENADORES DOMESTICOS 





r * ... t i. ¿t. -f i. ~* :. é j-J£2mi 

MI!''. , \ :\V 




ORDENADORES PORTATILES 




ORDENADORES DE GES~ Z 



Aplicaciones 



¿§J Ef precio , 

No podía faltar el condicionante econó- 
mico. Como se indicó en un párrafo ante- 
rior, los paquetes de aplicación estandari- 
zados resultan mucho más económicos 
que sus equivalentes confeccionados por 
encargo. En todo caso, es obvio que ta! 
economía sólo estará ai alcance si existe 
una aplicación estándar que satisfaga las 
exigencias impuestas por el usuario, 



DE LA APLICAC ION 

AnffiDENADQB^ 



La decisión de entrar en el universo de la 
informática parte, casi siempre, de la ne- 
cesidad de contar con un colaborador rá- 
pido y eficiente, que solucione una o múl- 
tiples tareas. Por supuesto, la entrada en 



la informática también puede tener su ori- 
gen en el interés por contar con un versá- 
til experto que amenice los ratos de ocio 
con los más diversos juegos 
En uno y otro caso, el origen está en la 
aplicación: en encontrar a un auxiliar que 
resuelva la papeleta de confeccionar dos- 
cientas cartas, cada una dirigida a un de- 
terminado cliente, en reemplazar a la cal- 
culadora y el lápiz por un cuaderno elec- 
trónico que calcule y actualice los supues- 
tos que reflejamos en sus casillas, o en 
reclutar a un jugador, experto y versátil, 
que llene de acción los ratos de ocio. 
Estas son situaciones que revelan el pre- 
dominio real de la tarea a resolver sobre la 
máquina que se ocupará de ponerla en 
práctica, EUj suario llegará a co nocer a su 
orr^njQ^ajravés de los pro g ramas de 
aglk:acIárrY r deéslos dependerá habituaU 
mente las prestaciones de la máquina 
Esta es una realidad que evidencia, a to- 
das luces, la importancia de los programas 
de aplicación. 

No ha de resultar ajeno, pues, oue un 



administrativo piense antes en las ca 
terístícas del programa que automatice 
contabilidad, que en el tipo de microp 
cesador, o en el número de conectares 
para comunicación externa, que incorpora 
el ordenador que debe adquirir. Estas úk- 
mas serán casi meros accidentes désete 
su perspectiva. 

También es lógico que un estudiante 
cuyo objetivo es repasar cómodamente 
los conceptos matemáticos y cazar naves 
espaciales en los ratos de descanso, opte 
por adquirir un equipo doméstico, antes 
que un sofisticado y potente ordenador 
gestión. 

La vía para informativa rse parte, habitu 
mente, del nivel de la aplicación, y recorre, 
en orden inverso, los restantes estratos 
del edificio informático: sistema operativo 
y hardware del ordenador. 
En definitiva, una vez que el futuro usua 
ha decidido cuáles son las tareas q 
debe resolverle la máquina, debe ir res- 
pondiendo a las siguientes preguntas q 
fe ayudarán a precisar la elección del ord 
nador personal idóneo: 

• ¿Existe aigún programa o paquete de 
programas en ei mercado, capaz de resol- 
ver, en todos sus matices, la aplicación? 

• Si existe, ¿para qué sistema operati " 
está concebido el paquete de aplicad 1 
que se considera idóneo para sofven 
sus necesidades? 

• ¿Qué ordenadores son los que incorpo- 
ran o admiten ei sistema operativo en 
cuestión? 

Y, por último, queda la labor de selecci 
nar el ordenador adecuado entre los q 
pueden ejecutar la aplicación deseada 
Para precisar la elección, es conven ient 
evaluar en este punto otros condiciona 
tes; por ejemplo: 

• ¿Los ordenadores considerados sor 
compatibles físicamente con el soporte 
de la aplicación? 

¿El disco en el que se entregan los progra- 
mas es compatible con ta unidad de discc 
del ordenador? ¿La máquina dispone de 
suficiente memoria residente para ejecu- 
tar la aplicación? ¿Es posible conectar a 
ordenador los periféricos idóneos al caso 
(impresora, terminal, digitador, trazade 
gráfico...)?... 

Todo un repertorio de cuestiones cuya 
respuesta conducirá a la elección del or 
denador idóneo para resolver nuestras ne- 
cesidades de automatización. 
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Basic 



Los datos del BASIC 



Ejecución de programas 
y recolección de datos 



!u 



n primer , conecto con la reali- 
dad del lenguaje BÁS i C lo pro- 
porciona, eí uso del comando 
P RINT , En sus distintas for- 
mulaciones, este comando permite trasla- 
dar información al órgano que refleja, a 
ojos del usuario, la actividad del orde- 
nador. 

Las posibilidades del comando PRINT no 
se limitan a la creación de los tipos de 
instrucciones cuyos formatos se analiza- 
ron en el capítulo precedente. Existen 
otras variantes, frecuentes en muchos in- 
térpretes BASIC, que amplían el abanico 
de posibilidades del PRINT, 



VARIANTES_DE LA 
INSTRUCCION PRINT 



o 

LO 
O 
0_ 



POSICION X 




Frint At (3,5) "Soft" 



Una de las variantes de la instrucción PRINT es la que incorpora ¡a función ATiX.Y). Esta 
permite seleccionar eí punto de impresión del texto que figura en el argumento. 



D or el momento sólo se han utilizado ins- 
trucciones PRINT formuladas de acuerdo 
3 su formato básico, cuya expresión gene- 
ral es: 

NL) PRINT <expresión ?>{[;] Mí<ex- 
oresión 2>... 

AJ utilizar este formato básico como ins- 
:njcción directa, hay que incluir el número 
de línea (NL). Este precede al comando 
D RINT y a su argumento que, cabe recor- 
dar, puede estar constituido por uno o 
varios datos o expresiones. 
Ciertos intérpretes BASIC, admiten otras 
cariantes en la formulación del comando 
D RINT además de la que se ha estudiado 
xmo caso genera!. 

Una de ellas es la que obedece al si- 
guiente formato: 

NL) PRINT AT(X,Y) <argumento> 



VARIANTES DE LA INSTRUCCION PRINT 



Formato: (Número de línea) PRINT AT(X,Y) <argumento> 

Ejemplos: 20 PRINT AT(20 r 12t "JUAN PEREZ" 
40 PRINT AT(5,3) "NOMBRE:"; ASE 

Definición: Escribe el argumento a partir del punto X r Y de la pantalla; siendo X el número oe 
columna e Y el número de fila. El origen de coordenadas se encuentra en el ángulo supencr 
izquierdo de la pantalla. 



Formato: (Número de línea) PRINT TAB(N); <argumento> 

Ejemplos: 45 PRINT TABÍ5); TABLA" 
60 PRINT TABÍ25); C$,D 

Definición: Escribe el argumento a N espacios de distancia del margen izquierdo de a 
pantalla. Actúa de forma análoga al tabuíador de una máquina de escribir. 



Formato: (Número de línea) PRINT SPC(N); < expresión T>: SPC(M); < expresión 2> 

Ejemplos: 30 PRINT SPCÍ7); "ARTICULO"; SPC(15) "PRECIO" 
40 PRINT SPC{10); AS; SPCÍ1S); P 

Definición: Imprime la expresión correspondiente a N fo M) espacios a la izquierda de 
posición en la que se encontraba el cursor. 
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Basic 




El destina de todo programa es su ejecución en el ordenador. La orden BASIC al 
efecto es RUN. 



La función AT(X r Y) que sigue a! comando 
PRINT permite al usuario precisar el punto 
de la pantalla en que desea visualizar el 
argumento. Para ello, debe especificar ios 
valores de X (columna: coordenada hori- 
zontal) y de Y (fila: coordenada vertical), 
teniendo en cuenta que el origen de coor- 
denadas se encuentra en e! ángulo supe- 
rior izquierdo de la pantalla (ver figura ad- 
junta). Por ejemplo, la instrucción si- 
guiente: 

PRINT AT(5.2) "JUAN" 

escribirá la palabra JUAN en [a segunda 
fila de texto de la pantalla y a partir de la 
quinta columna; o lo que es lo mismo, 
dejando cuatro espacios en blanco a partir 
del margen izquierdo de la pantalla. 
Otra de las variantes de la instrucción 
PRINT, resulta especialmente adecuada 
para escribir en la pantalla dejando un de- 
terminado número de espacios en blanco; 
algo semejante a lo que permiten las ta- 
bulaciones de una máquina de escribir. Su 
formato genérico es: 

(NL) PRINT TAB(N}; <argumento> 



Su utilidad es manifiesta a la hora de con- 
feccionar tablas, puesto que dando valo- 
res fijos a N, pueden seleccionarse per- 
fectamente las columnas en las que se 
realizará la presentación de los datos. 
Cabe indicar al respecto que el valor de N 
debe coincidir con el número de espacios 
en blanco que quieran dejarse desde el 
margen izquierdo de la pantalla hasta el 
punto de escritura del primer carácter del 
argumento. 

Existe una tercera variante también desti- 
nada a precisar el punto de escritura sobre 
la pantalla. Su formato es: 

(NL) PRINT SPC(N); <expresión í>; 
SPC(M); <expresión 2>... 



El dato o valor de la expresión que sigue a 
cada función SPC se escribirá tantos es- 
pacios a la izquierda de la última posicíór 
escrita como dicte el parámetro que 
acompaña a SPC (N, M...L 
Por último, hay que constatar que deter- 
minados dialectos BASIC, permiten ta 
sustitución de la palabra comando PRINT 
por el símbolo de cierre de ínterrogaciór 
(?}, No existe diferencia alguna en el com- 
portamiento y, realmente, la única justifi- 
cación se encuentra en el intento de hace^ 
más cómoda y rápida la escritura de las 
instrucciones PRINT. Por ejemplo, las dos 
siguientes líneas de programa son coi na- 
dentes desde el punto de vista de su eje- 
cución: 



20 PRINT "ALTERNATIVA AL COMANDO 
PRINT' 

20 ? "ALTERNATIVA AL COMANDO PRINT 

A lo largo de la obra habrá ocasión de 
comprobar la utilidad práctica de todas las 
posibles versiones de la instrucción 
PRINT dentro de los programas BASfC 



EJECUTANDO EL PROGRAMA 



El destino de cualquier programa no es 
otro que su ejecución en el ordenador. 
Para cursar esta orden a la máquina, 
existe un comando BASIC al efecto: 
RUN: 

Dada su naturaleza de comando de con- 
trol, RUN se utiliza a modo de instrucción 
directa, sin número de línea. Puede intro- 
ducirse en el ordenador en cualquier ins- 
tante en que el intérprete BASIC esté dis- 
puesto para recibir un mensaje, 




Orden para la ejecución del programa en curso, almacenado en memoria. 



Formato: RUN < número de líneax, H> 



Ejemplos: RUN 

RUN 26 
RUN 100,R- 
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_ ~ ecución provoca un borrado inicial de 
■, as variables en orden a que el pro- 
va no arrastre ninguna condición ini- 
:,e pueda entorpecer la ejecución y 

a un resultado erróneo, 
roducir el comando RUN desprovisto 
jumento, la ejecución empezará a 
- - ze la primera línea del programa. Si 

- ~ "3 necesario empezar la ejecución 

- :e cualquier otra línea distinta de la 
i nabrá que especificar el número de 

- :- en cuestión en la zona de argu- 

*: — ato genérico de una instrucción 
es el que sigue: 

- . , <número de línea> < R> 

: : no veremos más adelante, con oca- 
acr aei estudio de los archivos de infor- 
" r: : " e r \ el BASIC, la opción final "R'\ 

~ :e mantener abiertos todos los fi- 
:s de trabajo que ya se encontraban 

- i situación antes de ejecutar el pro- 



10 MAN DO END 



-^residad de instruir al ordenador pre- 
- : : .: ja le u ; e r m atiz, po r o bv i o q u e 
g^a^_es_una_íeaJj dad ca si _ p ro ve rb j a I 
'5 "uera preciso corroborarlo, aquí está 
■ ón END.. cuyo cometido no es 
: : ^ e ad vertí r al or denador q u e haj le - 
jp ai ITnahJ jH j^^ama. Por supuesto, 
li-e argumento alguno pare comple- 
i actuación de este comande, 
= : : _ sí solo, constituye una instrucción 




El ordenador es una máquina a la que es preciso instruir hasta el más mínimo detalle, hasta el 
panto de tener que comunicarle donde se encuentra el final de un programa 
por medio de ana instrucción EXD. 



Tras ejecutarla, el ordenador vuelve al 
«modo comando» (el cursor regresa a la 
pantalla) y el intérprete BASIC queda dis- 
puesto para seguir prestando su eficaz 
servicio de intermediario con la interiori- 
dad del ordenador. 



LOS DATOS DEL BASIC 



Sin lugar a dudas la misión primordial del 
ordenador es el tratamiento de los datos. 
Pero... ¿Qué tipos de datos? En esencia, 
un ordenador es una máquina de calcular, 




Instrucción de fin de programa. 
Formato: (Número de línea) END 




lo que significa que su mayor habilidad 
consiste en trabajar con números. De he- 
cho, sus circuitos más elementales sólo 
reconocen códigos numéricos (cadenas 
de ceros y unos). No obstante, un ordena- 



Ejempbs: END 
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dor dotado de un intérprete BASIC es ya 
capaz de identificar varios tipos de datos. 
En ef BASIC cabe d istingui r dos, tipos de 
datase 

• numéricos^ 

• alfanuméricos. 

Los primeros son nr más ni menos que 
números convencionales expresados, 
normalmente, en el sistema decimal. 
segundo tipo pertenece cualquier cadena 
de caracteres o conjunto de letras, núme- 
ros y caracteres especiales (signos de 
puntuación, etc.). 

Según esta clasificación, un número 
puede ser considerado como dato numé- 
rico o alfabético. Para diferenciar su natu- 
raleza, íos números utilizados como datos 
a Jf a numéricos suelen ir encerrados entre 
comillas, Por ejemplo: 7 es un dato numé- 
rico, mientras que "1" corresponde a su 
expresión alfanumérica. 
Ambos tipos de datos están presentes en 
cualquier programa BASIC. La evidencia la 
encontramos en algunos de los ejemplos 
propuestos al tratar ef comando PRINT. 
Al hablar de este comando, se introdujo el 
concepto de variable o referencia simbó- 
lica a la que pueden asignarse datos fijos o 
constantes. Las variables tienen en el BA- 
SIC una función parecida a la propia de fas 
variables matemáticas. Estas últimas se 
utilizan para designar a un dato descono- 
cido o que puede tomar diferentes valo- 
res. En el lenguaje BASIC, las variables 
tienen un «nombre» que sirve para identi- 
ficarlas, y un «contenido» o valor que 
toma la variable en un determinado mo- 
mento. 

Una de las operaciones mas frecuentes 
dentro de un programa es, precisamente, 
la de afterar el contenido de algunas varia- 
bles. Este proceso se realiza por medio de 
denominadas «sentencias de asigna- 
ción», cuyo cometido es asignar a una 
variable su correspondiente valor. Este 
coincidirá con un dato de uno de los dos 
tipos comentados. Una vez realizada fa 
asignación, el valor o contenido de una 
variable puede ser utilizado como un sim- 
ple dato. El comando encargado de la 
asignación es LET. Su formato es el si- 
guiente: 

LET <nombre de variable> = <expre- 
sión> 

El campo denominado <expresión> 
puede contener un número, una cadena 
de caracteres o, en general, una combina- 
ción de datos y operadores. Por supuesto, 
los datos pueden ser constantes o valores 



numéricos o alfanuméricos o, sencilla- 
mente, nombres de variables representa- 
tivas de su contenido. Las siguientes son 
asignaciones válidas: 

LET Pl=1141592 
LET NOM$="PAC0" 
LET SUMA=5+3 
LET LÜNG=2*PI*R 

En el primer ejemplo se asigna a fa varia- 
ble Pl el valor numérico 3.141592. Una 
vez definida una variable, ésta puede ya 
utilizarse como dato en otra asignación; la 
cuarta instrucción LET, utiliza la variable Pl 
(definida en la primera línea) dentro de la 
expresión cuyo resultado se asigna a la 
variable LONG, Como $e observa, para 
acceder ai valor de una variable basta tan 
sólo con «llamarla» por su nombre. 
El siguiente programa utiliza tres instruc- 
ciones de asignación: 



una circunferencia de distinto radio, basia 
con otorgar a R el nuevo valor dentro de ta 
mencionada instrucción. 



10 LET R=5 

20 LET Pl=3.141592 

30 LET L0NG=2*PPR 

40 PRINT "LA LONGITUD ES: LONG 

50 END 

RUN 



LA LONGITUD ES: 31.416 



Cabe observar que los números aparecer 
en notación inglesa, sustituyendo a ía| 
coma decimal por un punto. Esta es um 
característica casi generalizada en los in- 
térpretes BASIC. 

En la mayor parte de los dialectos BASIC 




Datos Numéricos 



Datos Alfanuméricos 



En el lenguaje BASIC coexisten dos tipos de datos; numéricos (números convencionales 
expresados, normalmente, en el sistema decimal) v alfanuméricos o cadenas 
de caracteres f conjuntos de letras, números v caracteres especiales). 

10 LET R=5 
20 LET Pl= 3.141 592 
30 LET L0NG=2*P(*R 
40 PRINT 'LA LONGITUD ES: "; LONG 
50 END 

El ejemplo calcula la longitud de fa circun- 
ferencia cuyo radio (R) se especifica en la 
línea 10. Para determinar la longitud de 





Asignactón de datos o expresiones a variables. 

Formato: (Número de línea) LET <nombre de variable > = < expresión > 

Ejemplos: LET A=7 

10 LET AXS=' VARIABLE" 
20 LET SUMA=2Q+250+C 
30 LET LONG = 2*PI*R 
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Variables 
Numéricas 



000 

A X DAT01 




VAL2 NUM 



LET A = 27 1 



s presencia de la palabra LET es opcional; 
:.ede omitirse el comando manteniendo, 
z*z r supuesto, el formato característico de 
35 instrucciones de asignación. El ejem- 
: : anterior adoptará, en este caso, la 

■ R=5 

M Pl =3/141592 
3 L0NG=2*PI*R 

m PRINT "LA LONGITUD ES: "; LONG 
a END 

l ^na$ versiones del BASIC admiten la 
: : s'bilidad de realizar múltiples asignacio- 

. •• dentro de una misma instrucción LET. 
E dato o expresión se asigna simultánea- 

snte a todas las variables que lo prece- 
den. Por ejemplo: 

_ET A=B=C=25 

: - asta ocasión, las variables A, B, C to- 
■án todas ellas el valor 25. 



RECOLECTANDO DATOS 



este punto de la obra, el BASIC ha 
:j£Svelado ya algunos comandos de su re- 

lorio. Comandos Otiles para realizar un 
^terminado tratamiento de la informa- 



Variables 
Alfanuméricas 



A$ X$ 




NOM$ DATO $ 



i LET A$ ■ "CASA* I 



ción: PRINT {presentar datos e~ ta paota- 
lla) r LET (asignar datos a vanacesj... Se 
han aportado, incluso, algunos : F :c r 3mas 
sencillos pero ilustrativos de : ss czs b¡ i ida- 
des que brinda el BASIC para manipular 
datos. 

Parece obvio que el próximo paso hay que 
darlo en el sendero de los daros; presen- 
tando uno de los comandos EAS;C desti- 
nado a la captación de datos. .1N.PUT es 
uno de los comandos de esta categoría. 
Su especialidad es la de gestionar la en- 
trada de datos durante la ejecución del 
programa. Ai encontrar una instrucción IN- 
PUT, el ordenador detiene la secuencia de 
ejecución y solicita al usuario los datos 
exigidos por la mencionada "rsirucción. 
La captación de datos a través de INPUT, 
se reduce a un proceso de asignación. 
Veamos un ejemplo introductorio: 




La línea 20 revela uno de los formatos 
tradicionales de la instrucción INPUT: el 



comando, seguido de una variable. Como 
ya se ha mencionado, la introducción de 
datos se concreta en una asignación. En el 
ejemplo, el dato que se introduzca que- 
dará asignado a la variable AS., que consti- 
tuye el argumento; por supuesto, la natu- 
raleza alfanumérica de la variable (AS) 
obliga a que el dato de entrada sea una 
cadena de caracteres. 
Regresemos de nuevo al ejemplo. A! lle- 
gar a la instr^c^ónJN PUT, se detiene e l 
Pjpces c^de_ei gcución y aparece un inte - 
r rogante en la pan tajla. 
El signo de interrogación que precede al 
cursor indica, ni más ni menos, que el 
prog r ama a guar da a qu e el usuarin intm- 
d uzca un dal o. Para que la ejecución 
pueda continuar, es necesario introducir el 
dato solicitado, seguido por una azzz^ 
sobre la tecla RETURN. El efecto ce ? 
orden RETURN no es otro que identifica- 
el final del dato. 




Tras recibir el dato en cuestión, el ordena- 
dor vuelve a ocuparse del programa: 
asigna a A$ el dato "MANLE. - 
medio de la instrucción 40, lo v's^a ::- 
la pantalla precedido del mensaje 
"HOLA". 

Ya se ha mencionado el hecho de que fe 
variable de solicitud de date -S e~ e 
ejemplo) puede ser numérica : 5 J =~_~^ 
rica, exigiendo, en cada caso, uodatotie? 
tipo solicitado: número o cadena de carac- 
teres 

Son muchas las posibilidades rjue este 
comando pone al alcance de ,s.r: _ - 1 
de ellas deriva de la posibilidad de introdu- 
cir un mensaje en el argume n :c z& 
de tal forma que ia solicitud ce zzzzz ~ : : 
pore un texto al efecto, 
Veamos un ejemplo. Se traía, serosa- 
mente, de un programa capaz ce 1= :_ =- 
el precio total de un determirsc: ~_~^"c 
de artículos del mismo tipo. Bjwggsma 
incluye las instrucciones W z - ^ 
rias para pedir al usuario la cani :.t 
artículos vendidos y el prec'c zz- _ - : = : 



LET es el comando BASfC adecuado para construir ¡as instrucciones de asi£$#gofi. Su 
jumento contiene el nombre de la variable y el dato a asignar a la misma: amSas elementas, 
:c i t mudos por W signo "igual" ( = .), deben ser del mismo tipo {numéricos o alfamtménvos). 



Basic 





El teclado es la principal vía para la entrada de ciatos al ordenador. Para gestionar su 
introducción, el BASIC cuenta con instrucciones especializadas: por ejemplo, 
las que pueden construirse a partir del comando INPUT. 



En esta nueva versión del ejemplo inicie 
se observa que al utilizar la coma como 
elemento separador desaparece el signe 
de interrogación que visualiza el BASIC. 
Otra particularidad adicional. Si el co- 
mando INPUT inmediatamente va se- 
guido por un punto y coma, la orden RE- 
TUR N que pone fin al dato introducido nc 
provocará un salto a la siguiente línea de 
impresión El cursor permanecerá junto s' 
dato ingresado por el usuario. Ello supone 
que el próximo mensaje se visualizará e- 
la misma línea. Para observar el resultado 
basta con modificarla línea 10 del ejemplo 
anterior. 

10 (NPUT; "INTRODUZCA SU NOMBRE", AS 

El resultado de la nueva ejecución será: 



RUN 



10 INPUT "CANTIDAD: "; C 
20 INPUT 'PRECIO UNITARIO": "; PT 
35 PRINT "IMPORTE TOTAL: "; C*PT 
40 END 
RUN 

CANTIDAD: ?5<R?! 
PRECIO UNITARIO: ?30 (RT) 
IMPORTE TOTAL: 150 



Otra de las virtudes de INPUT es que tras 
la introducción de un dato erróneo, no 
«rompe» la ejecución del programa. En su 
fugar muestra un mensaje de error y, a 
continuación, vuelve a solicitar ei dato 




El signo separador entre el mensaje y la 
variable que recoge el dato introducido 
puede ser una coma en fugar de un punto 
y coma. Esta alternativa suprime ta inte- 
rrogación. 



110 INPUT INTRODUZCA SU 
NOMBRE: * AS 
20 PRINT "HOLA"; AS 
30 END 
RUN 

INTRODUZCA SU NOMBRE: MIGUEL (RT) 
HOLA MIGUEL 



INTRODUZCA SU NOMBRE PABLO. HOLA 
PABLO 




Al ejecutar una instrucción INPUT t el ordenador detiene la secuencia de ejecución v solicita al 
usuario el dato a asignar a la variable que constituye su argumento. 



Por último, cabe añadir que una sola ins- 
trucción INPUT es perfectamente utiliza- 
ble para la captación de varios datos, e 
incluso de distinto tipo. I es cates in Acae- 
cidos se irán asignando, ordenadamente, 
a las variables incluidas en el argumento 
El número de datos introducidos debe ser 
igual al número de variables que aparecen 
en la lista y r por supuesto, su naturaleza 
(dato numérico o altan umérico) debe coin- 
cidir con la de la variable correspondiente. 
Por ejemplo: 

INPUT TRES DATOS"; A,B,C 
INPUT "FECHA(AÑO r MES r DIA)"; 
A r MESS r DIA 

En el primer caso, hay que responder con 
tres datos numéricos. No obstante, como 
rGSpuesta a la segunda instrucción INPUT 
será preciso introducir un número (A: a ño), 
seguido por una cadena de caracteres 
ÍMESS), para terminar con un nuevo valor 
numérico (DIA). Tanto en este caso como 
en cualquier otra situación análoga, en la 
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TABLA DE CONVERSION (1) 


DRDENADOR 


RUN 




LET 


RUN 


RUN ni 


END 


LET <var > = <expr > 


<var.>=<expr.> 


APPLE II 

APPI F^nFTl 
Arri,cour i / 


RUN 


RUN ni 


END 


LET <var> = <expr,> 


<var> = <expr> 


»Sj n 1 uu 1 

M-BASIC} 


RUN 


RUN rl 


END 


LET <vai\> = <expr.> 


<var.> = <expr> 


ATAR! 


RUN 


RUN ni 


END 


Lt [ <var.> = < expr.> 


<var,-> := --.sxpr.^ 




RUN 


RUN ni 




Lt i ^.var.>=<expr.> 


< var, - sxp r_ -> 




DI IM 


DIIM ni 

KUIM ni 


FND 


Lt i - var. -■ — ■-- expr j> 


vüi , -- — -- cxp r . — ^ 


=n hipos 

wsx 


RUN 


RUN ni 


END 


LET <var>^<expr> 


<var.>=<expr> 




Rl IM 


Rl IM ni 

nUiN ni 


END 


1 U T ■r-"'i¡i'i¡ r — i- -- avn r 

i ^var. — ^-cApr,-^* 


\jn r — J ---" avrir "":> 
^-i ¥ fl. \ . .-- * — ---.BAfJf.^ 


cu pp 


t 

Rl IM 


Rl IM ni 

nUN ni 


END 


leí ^-.var.-^ — ^expr.- 5 * 


-- va i , .-- — -- c a.|J j . - 


,'PF 


RUN 


RtJN ni 

nu i ii iii 


END 


LET <!uar ":> = ■=-/' p x n r > 


< var > = <expr.> r 


HCR DM-V 
MS-BASIC} 


RUN 


RUN ni 


END 


LET <var.> = <expr> 


<var>-<expr> 


VEW BRA1N 


RUN 


GOTO ni 


END 


LET <var> = <expr> 


<var.>-<expr> 




RUN 


RUN ni 


END 


LET <var>=<expr.> 


<var,>-<expr> 


SHARP MZ 700 
MZ-BASIC) 


RUN 


RUN nt 


END 


LET <var.> = <expr.> 


<var> = <expr> 


5JNCLAIR QL 


RUN 


RUN ni 




LET <var.> = <expr,> 


<var> = <expr/> 


3PECTRAVI0E0 


RUN 


RUN ni 


END 


LET <var> = <expr> 


<var> = <expr,> 


ZX-SPECTRUM 


RUN 


RUN ni 




LET <var > ~<expr > 


<var> = <expr> 



_r~ero de línea. <var> : Variable. <expr> : Expresión. Dato c combinación de datos numéricos o alfanuméricos. 
MULACIONES DE LOS COMANDOS 

Eecuta en su totalidad el programa que se encuentra en la memoria central RUN ni: Ejecuta eí programa 3 partir de la línea específica (ni). END: Señala el final del 



aya que introducir varios datos como 
lesta aun INPUT, éstos se separarán 
^edio de una coma, 
^satllidad que permite el comando 
T puede llegar a simplificar las tareas 
: carnación ríe forma más que apre- 
: Es al usuario a quien corresponde 



: : -AV.A 



PETICION DE DATOS 



DATOS ? 

3 



*Q | 



optar por la formulación idónea en cada 
caso. 

Un simple programa, capaz de pedir la 
introducción de una serie de seis núme- 
ros, operar la suma y presentar el resul- 
tado en la pantalla, puede ilustrar la impor- 
tancia que adquiere la elección del método. 



en;rája de datos 



DATOS ? X 



0 



instrucción INPUT es utili'.abie para la captación de varios datos, incluso de 
" Ti ¡. Tras introducir los daros, hay que accionar la tecla RFTURN 
■r prosiga la ejecución del programa. 



20 LET S=Ü 

30 INPUT "A";A 

40 LET S=S+A 

50 INPUT J 'B ";B 

60 LET S=S+B 

70 INPUT "C";C 

80 LET S=S+C 

90 INPUT "0 ";D 
100 LET S=S+D 
110 INPUT J E";E 
120 LET S-S+E 
130 INPUT "F";F 
140 LET S=S+F 
150 PRÍNT "SUMA TOTAL- ";S 
ISO END 

Es evidente que el procedimiento elegido 
no es el más adecuado. El comando IN- 
PUT admite otras formulaciones capaces 
de reducir la longitud del programa y ha- 
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TABLA DE CONVERSION (2) 


ORDENADOR 


INPUT 


INPUT <var.> 


INPUT "<mens,>";<var> 


INPUT "<mens.>",<var.> 


INPUT <var r 1>,<var. 2>.,. 


INPUT;"<mens.>"... 


APP1£1 

APPLESOFT) 


INPUT <var> 






INPUT <var. 1>,<var 2>... 




!M-BAS*C) 


INPUT <var> 


INPUT "<mens>";<var.> 


INPUT "<mens.>" H <var > 


INPUT <var 1>,<var. 2>.„ 


INPUT;"<mens>"... 


ATARJ 


fNPUT <var> 






iNrui <var i >,<var. ¿>... 






INPUT <vaf> 


INPUT "<mens.>";<var.> 




1 h.1 OI IT >lmr 1 J J ■ J.L. l> O -"-i- 

INrUI <var. l>><var, ¿>... 




uKACjury 


INPUT <var> 


INPUT "<mens.>";<var> 




INrUI <var. i>,<var. ¿>... 




MSX 


INPUT <var> 


INPUT "<mens>";<var.> 


INPUT "<mens.>",<var,> 


INPUT <var. !>,<var 2>~< 


INPUT;"<mens>".., 


un ten 
Mr- 150 


INPUT --var.-^ 


INPUT "<mens.>";<var > 


INPUT "<mens.>" r <var.> 


INrUI < var, i^^var. ¿>... ¡ 


INrUI, <mens.> 


id lifl un 


inpu l <var.> 


INPUT ' J <mens,>";<var > 


INrUI <mens.> r <var.> 


INrUI <var. i>,<var. ¿>... 


lEvru i p <Ttiens.> ,.. 


lYlr r 


IMPI IT í-uar ^ 




INTUI ^- 1 1 leí lis. r ^-Vdl,-* 


1 1 *J T U I ^-Voí, 1 -- r --- Vd 1 , £ r , . 




NHR DM-V 
(MS-BASIC) 


INPUT <var> 


INPUT ' J <mens,>";<var.> 


INPUT "<mens.>",<var> 


INPUT <var. l> H <var. 2>.„ 


INPUT;"<mens,>".,. 


NEW BRAIN 


INPUT <var.> 




INPUT ("<mens >l<var> 


INPUT <var. l> H <var. 2>.., 




ORIC 


INPUT <var> 


INPUT "<mens >";<var> 




INPUT <var. 1>,<var. 2X.. 




SHARP MZ-700 
(MZ-BASIC) 


INPUT <var> 


INPUT "<mens>';<var r > 




INPUT <var. 1>,<var. 2>... 




SINCLAIR QL 


INPUT <var> 


INPUT "<mens.>";<var.> 




INPUT <var, 1>,<var, 2>, 




SPECTRA VIDEO 


INPUT <var> 


INPUT "<mens.>";<var> 




INPUT <var 1>,<var. 2>,.. 




ZX-SPECTRUM 


INPUT <var > 


INPUT J '<meris>";<var\> 




INPUT <var. 1>,<var. 2>„. 





<var.>: Variable. <mens.>; Texto o mensaje. 
FORMULACIONES DEL COMANDO INPUT 



INPUT <var >: Entrada de un dato asignándolo a la vüriüblu indicada. INPUT "<mens.>";<var>: Entrada de un dato con presentación del mensaje en la pantalla seguido 
por el signo de interrogación. INPUT ' J <mens.> r \<var.>: Entrada de un dato con presentación del mensaje omitiendo el signo de interrogación. INPUT <var. 1>.<var. 
2>„,: Entrada de un conjunto de datos, separados por comas, asignándolos a las variables en el orden en el que éstas aparecen. INPUT; "<mens>"...: Entrada de datos sin 
que se produzca un salto de línea tras su introducción. 

cer más cómoda la introducción de los Ambos programas son de todo punto 




datos. Por ejemplo: 
20 INPUT "A # B f C 1 D,E 1 F';A I B,C P D r E í F 
30 LET S=A+B+C+D+E+F 
40 PRINT "LA SUMA ES: "; S 
50 END 



equivalentes; introduciendo los mismos 
valores en ambos casos, el resultado será 
el mismo. Sin embargo, no cabe duda que 
el procedimiento correcto es el utilizado 
en el segundo programa. 



Asigna el valor introducido por el teclado a fa variable indicada. 

Formato: (Número de línea) INPUT [;] ["<Mensaje>" 1 <var. l>[ t <var. 2>.,.l 

Ejemplos: INPUT AS 

INPUT "VALOR J ';V 
INPUT J 'DIA",D 
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Lenguajes 



Logo (2) 

El primer contacto 
con el lenguaje de la tortuga 



in lugar a dudas, la caracterís- 
tica más espectacular del 
£0_GQ._.se encuentra en el 
TURTLE GRAPHICS. Un méto- 
: 2= dibujo que consiste, en desplazar 
■muga a través de la pantalla; éstajrá 
- ^do el dibu jo al d ejar vi sible el_rastro 
. :rayector¡a en los sucesivos movi- 
- - _ :os. Crear un dibujo se convierte, 
2^5 en algo tan simple y divertido como 
ij^ el desplazamiento de tan simpático 
^sonaje. 



"3CT0 v DIBUJOS 
Sí LA PANTALLA 



w _r_de¿airpj|ar el conjunto de posibles 
_j25Üg$ que brinda el LOGO, éste ad- 
t tjes tipos o formatos de pan ta Na : 

^ = = ~:alla de texto 
— • 'entalla de gráficos y 
_ • z :-~:al¡a partida. 

^ "zoia denominación que recibe cada 
de pantalla revela su utilidad: ja, 
~^-3_está destinada a la present ación 
=: "rxto la segunda a la visualización d e 
^^■c os^y la_ tercera, denom i nada pa ntalla 
za_o ^ fracciona da, comparte ambas 
: dades. 

: i ' mera modalidad (pantalla de texto) 
i =s posible ver a la tortuga y tampoco a 
" : . os trazados con su colaboración. 

- :do de presentación sólo resulta 

- ..--20 para la escritura de texto y 
i-Err: ser el inicial, presente en el instante 

" "T^tar el ordenador 

=i'ed e r a la tortuga es preciso cam - 



biar a otra modalidad de pantalla; para 
ello, basta con teclear un determinado co,- 
manobjgjáico. El efecto de tai acción será 
el/salto a la pantalla de gráficos o a la 
pantalla partida. 

Los comandos gráficos que permiten el 
"salto" a una nueva modalidad de pantalla 
son: FS , TS y SS. 



El primero de ellos (FS: Ful! Screen) re- 
serva toda la pantalla para gráficos. Si se 
introduce algún texto después de utilizar 
el comando FS, el usuario observará que 
su mensaje no aparece reflejado en nin- 
gún punto de la pantalla. 
Si el comando introducido es SS (Split 
Screen), quedará seleccionada la pantalla 




El LOGO es uno de los lenguajes más frecuentes en ordenadores de tipo doméstico. Son 
machos los modelos para los que existe el adecuado traductor de LOGO, como alternativa ai 
intérprete BASIC habitúa i, 
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pa-r - :e*z: =i=-e:e-= ~- s 'rc- 
rior de te misma, mientras que la zona 
superior quedad reservada a las evolucio- 
nes z± t ""^zz 

E z^zí'z zí := comandos, TS (Text 
:r^^;:::5 3 pantalla a la visuali- 
za:^" :a:e = :: s n dejar resquicio alguno 
Zz-z z. zz-z^a. 

-eí_-- :: 5 Tensivamente de FS a TS. 
pueden ir observándose las órdenes intro- 
ducidas y su ejecución en modo gráfico. 
Sin embargo, resulta más cómodo el uso 
:e z. za~'.a a partida, tal como tendremos 
ocasión de estudiar con detalle en los ca- 
pítulos dedicados a TURTLE GRAPHICS, 



COMANDOS Y OPERADORES 



En el LOGO es muy importante el con- 
cepto de entrada y salida de datos. Imagi- 
nemos dos máquinas tragaperras, una de 
ellas expendedora de chicles y la otra un 
video-juego de "marcianos". En la pri- 
mera, al introducir la moneda (dato de en- 
trada), sale de inmediato un paquete de' 
chicles (dato de salida). Por contra, al in- 
troducir [a moneda (dato de entrada) en la 
máquina de video-juegos, no cae una 
nave galáctica por la ranura inferior (no hay 
dato de salida. Realmente, estarnos otor- 
gando la cualidad de "tangibles" a ios da- 
tos de nuestro ejemplo, con lo cual, pa- 
rece que no hay dato de salida en el se- 
gundo de los casos. Pasemos ahora a la 
c oncreción de JJ-QGQ. Para empezar, hay 
que tener m cuenta que las órdenes o 
instrucciones pued enser de dos tipos: 

• comandos u 
^ • operadores 

(según la terminología propia de este len- 
guaje). 

La diferencia entre ambos tipos de ins- 
trucciones radica en que un co mando e s 
una orden que puede o n ojene r datos de 
entrada^ perojjue^ nn jngún caso pro por- 
ciona dato de sal ida , (et ejemplo de la má- 
quina de video-juegos). Por el contrario, .eL 
qger ador es una orden que proporciona 
s iempre algún_da Jo_de_saiida (la máquina 
expendedora de chicles). 
Por ejemplo, la orden FO RWARD iLe s-iin. 



comando: mueve la tortun fl cinco esna- 
c ios hacia_a g!eia nt e (5 es el dato de -en - 
trada^ pej^ono_j^rop^ 
de salida. Enj:aj^Íg_5 ,L^^ 
nútmeros_2Jí'..3 .entreg ando, e.1 jriimg roj^ 
como resultado. Las cifras 2 y 3~soñ datos" 
de entrada, mientras que 5 es el dato de 
salida^ Por lo tanto, SUM será un ope- 
rador. 

En el LOGO, las órdenes o instrucciones 
deben redactarse de tal forma que empie- 
cen por un comando, puesto que los cia- 
tos de entrada van siempre al final de la 



instrucción. Esta condición !a observamos 
en cualquier orden, por ejemplo: 

FORWARD 5 

en la que el comando (FORWARD : hacta 
adelante) precede al dato de entrada (5). 
Los datos de entrada pueden coincidir, 
incluso, con los datos de salida de un ope- 
rador. En la siguiente instrucción: 

FORWARD SUM 2 3 

se ordena a la tortuga que avance un nú- 
mero de posiciones coincidente con el re- 
sultado de sumar 2 y 3. Por lo tanto, el 



FANTA.LA DE TEXTO 



MAKE " NUM 7 
PRtNT SUMNUM 
250 



PANTALLA GRAFICA 



PANTALLA PARTIDA 





1 


f -1 

* 






MAKE ,L SUELDO 20 
L MAKE PLUS 5 




Las tres pantallas del LOGO' de texto, gráficos y pan tafia ! partida \ El salto de una a otra se 
produce al utilizar los comandos TS\ FS o SS. 



Un operador 
LOGO rec ibe los 
datos de" entrada 
v entrega un dato 
de salida. Este 
dato de salida 
puede pasar a 
formar parte de 
los datos de 
entrada de an 
comando 
destinado a 
realizar una 
acción 
específica. 



4 DATO DE ENTRADA 
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Estructura de una instrucción LOGO. El comando que define la acción a realizar se mure de ios datos de salida generados por los operadores 
me lo acompañan. 



.r.c de entrada del comando FORWARD 
e s el dato de salida del operador SUM 2 3. 
- su vez, las entradas de SUM podrían 
;o incidir con los datos de salida de otros 
aeradores. En todo caso, hay que reco r- 
-^r_qiip bjTrimftra paiahra c\r la orden o 
'strucción debe ser un coma ndo; de lo 
■ :^tr anq_se perdería el dato de salida. g e- 
nerado por el operador que lo sigue . Vea- 
mos un ejemplo^ La instrucción siguiente: 

SjJM2g 4 20DQ 

'eaji za la sunn ajej os dos númerosj ndica- 
: : s . "sin em b^rgoTeí resultado ño^seutiliz a 
i^Tanlir^áTr^ 



En tal caso, el LOGO mostrará en ia panta- 
lla un mensaje de error: 



SUM 284 2000 



YOU DONT SAY WHAT 
TO DO WITH 2284 





(¡No me has dicho qué debe = con el 
dato de salida 2284!}. 



LAS VARIABLES DEL LOGO 



Además de operadores, comandos y da- 
tos, existen otros elementos en las ins- 
trucciones LOGO: lasvüñahies. 
De forma simple, aunque ilustrativa, 
puede considerarse a la variable como un 
co m p artimento cap_ az_de co ntenendato s . 
Entoda "variable hay quejkiistinguirjdos 
partes: 

• nombre_ d e la varia ble y 

• contenj do. 

El conten id^ues^eL va loxj del dato almac e- 



Instruyendo a la máquina 



El ordenador es una herramienta capaz 
de demostrar su utilidad y eficacia en 
múltiples actividades. Para que su 
capacidad se vuelque en la práctica, es 
preciso "instruirlo", comunicarle, con toda 



suerte de detalles, qué debe ^-.z-r . 
cómo debe hacerlo. 

Educar a la máquina, prograrra r a. supone 
redactar una completa "receta zs 
instrucciones; o lo que es le ^ eto. 





confeccionar un programa utilizando el 
lenguaje propio del ordenador. 
Si queremos que un cocinero nos prepa re 
u rTpIato queBescoñoce, esTprecisQ darle la 
receta: una serie de instrucciones 
detalladas que, ejecutadas en su estricto 
orden, permitirán cocinar el plato. Hay 
ciertas instrucciones que deben ser 
especialmente detalladas; por el contrario, 
otras como "freír' r o "pelar", son de sobra 
conocidas por el cocinero y no exigen 
mayores precisiones. Hay que tener 
cuidado para no cometer errores al escribir 
la receta, puesto que no es lo mismo "pollo 
frío" que "pollo frito" 
Nuestro cocinero es el ordenador, alguien 
capaz de preparar cualquier plato que se 
nos antoje, por supuesto, siempre y cuando 
se le entregue la receta (el programa) 
adecuado. 

Una vez que se conozca con detalle el 
lenguaje del ordenador, su aplicación a 
cualquier actividad práctica llegará a 
constituir una tarea tan cómoda y habitual 
como realizar la colada. Sabemos cómo 
comunicarle las instrucciones y cómo 
aportarle los datos. El se ocupará de 
procesar los datos de acuerdo a las 
instrucciones del programa, y entregará el 
resultado con prontitud y precisión. 
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TABLA DE ORDENES-LOGO 


Instrucción 


Cometido 


0 pera d o r/Coma ndo 


FS 


Selección de 
pantalla gráfica 


Comando 


TS 


Se fe celó n de 
pantalla de texto 


Comando 


ss 


Selección de 
pantalla partida 


Comando 


MAKE"<palabra> <dato> 


Definición de 
variable 


Comando 


PRINT <objeto>* 


Muestra el <objeto> 
por pantalla 


Comando 



<objeto>: puede ser una palabra, una lista, un número o una variable. 



print 



sum 



3 

asoii 



first 



vaca 



Cualquier instrucción LOGO debe empezar con un coma mío. Si su tugar estuviera ocupado por 
Ufl operador, la instrucción no ejecutaría una acción y se perderían los datos de salida 
de ¡os operadores previos. 



MAKE SUELDO 5000 




MAKE es eí comando apropiado para definir una variable LOGO; debe estar seguido por el 
nombre de variable (precedido por comillas) y por el dato a asignar. 



pado-emjicho rec i p i e nrejzya hable, mien- 
tras que el nombre es la palab ra que iden - 
t ifica, a cada_ variable^ y la üi^hgue jor 
cornpletp de lasj£5íantes. 
Cabe suponer que las variables son algo 
semejante a los cajones de un armario 
clasificador. Cada cajón tiene una etiqueta 
que sirve para identificarlo y, por su- 
puesto, dentro del cajón pueden almace- 
narse distintos objetos (datos). En el caso 
que nos ocupa, cada variable tiene un 
nombre que la identifica con exclusividad 
y en ella podemos almacenar muy diver- 
sos valores numéricos. 



Por lo demás, podemos acceder al conte- 
nido de un cajón (al dato) a través del 
nombre que lo identifica (ef nombre de la 
variable). Un buen ejemplo para ilustrar 
estos conceptos lo encontramos en el fi- 
chero de clientes de una empresa. El 
identificador de cada una de las fichas 
coincide con el nombre del cliente y p 
desde luego, es posible consultar una de 
estas fichas para obtener información. 
También se puede actualizar su conte- 
nido, ya sea borrando, añadiendo o susti- 
tuyendo datos. De forma análoga, tam- 
bién es posible consultar, modificar o bo- 



rrar a voluntad el contenido o dato asig- 
nado a una variable. 

Los datos de entrada incluidos en una or- 
den, pueden definirse como el contenido 
de una variable, en lugar de expresarlos 
en forma de valor numérico fijo Por 
ejemplo: 

SUM ;DAT01 :DAT02 

suma el contenido de las variables DATOl 
Y DATÜ2 

Para definir cualquier variable, es preciso 
utilizar un comando al efecto: MAKE 
(Hacer), 

MAKE admite dos datos de entrada; eí 
primero es el nombre con el que se desea 
identificar a la variable, mientras que eí 
segundo coincide con el dato que se de- 
sea almacenar en la misma. 
El nombre se puede elegir libremente, sí 
bien, suele utilizarse una palabra relacio- 
nada con la naturaleza del contenido que 
va a almacenarse en dicha variable. Por 
ejemplo, si una variable va a contener un 
número correspondiente al sueldo que 
percibe un empleado, lo más lógico es 
otorgar a la variable en cuestión el nombre 
SUELDO. Hay que precisar, que el nom- 
bre de la variable hay que introducirlo pre- 
cedido por comillas ("). Eí motivo se co- 
mentará en el capítulo dedicado a las "pa- 
labras y listas" del LOGO 
El segundo dato que acompaña al co- 
mando MAKE debe coincidir con ef valor 
que se desea otorgar a la variable. Más 
adelante, se verá que el dato en cuestión 
puede ser de varios tipos, incluyendo la 
propia salida de un operador o el conte- 
nido de otra variable. Por ejemplo: 

MAKE "DJA3D 

asigna a la variable DIA el valor 30. 
A la hora de acceder al contenido de la 
variable, bastará sencillamente con indicar 
el nombre de la misma, precedido por el 
signo "dos puntos" (.). Si la instrucción al 
efecto la empezamos con el comando 
PRINT; 

PRINT :ü\A 

al ejecutar la orden, accionando la tecla 
RETURN, el contenido de la variable (DIA 
en nuestro caso) aparecerá escrito en la 
pantalla. El signo "dos puntos" que pre- 
cede a la palabra DIA, indica al LOGO que 
se trata, precisamente, del nombre de una 
variable. 
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Evaluación de un S.O 



¿ Qué hay que exigirle 
a un sistema operativo? 



odo el conjunto de posibilida- 
des delsjistema ..QperatLvo_de- 
ben tend er a un objetivo bá- 
sico: acercar el ordena dor al 
^suaricj , poniendo a disposición de éste 
"idos los recursos de máquina. Una labor 
ue obliga al S.O. a aportar las herramien- 
tas necesarias para tal fin. 
£ usuario suele repetir constantemente 
' determinado tipo ce operaciones, con 
es que es capaz de llevar a cabo sus pro- 
pósitos. Por este motivo, el sistema ope- 
"rtivo incorpora todo un abanico de pro- 
va mas de utilidad capaces de facilitar el 
-anejo de datos y programas. Veamos 
:uáles son las utilidades más frecuentes. 
La instrucción de los datos y del propio 
sexto de los programas fuente en los co- 
-^spondientes archivos, puede llegar a 
ser una tarea poco grata si no se dispone 
3e un método eficaz para hacerlo. Con la 
3*uda de ur editor de textos el trabajo 
gsultará bastante más cómodo al dispo- 
ner de utilidades que permiten la correo 
: tn de errores, la localización de un cierto 
cemento dentro del conjunto de datos, el 
cambio de un valor determinado por otro, 
= Dorado y ía inserción de nueva informa- 
: ra todo un largo etcétera de funciones 
r^e dependerá de la potencia del editor 
- " cuestión. 

de los problemas más críticos en 
"ico sistema informático es el de garanti- 
sr la integridad de la información puesta 
en juego, dado el gran volumen que se 
-aneja. La protección y restricción del ac- 
t50 a los datos deben ser factores con- 
:=-npfados por el sistema operativo, de 
^~na que tan sólo cierto tipo de usuarios 
D.edan acceder y modificar los datos al- 

- ^cenados. 

- -: stema operativo permite el manejo de 
"formación contenida en los ficheros, 

rrndando al efecto utilidades para facilitar 
eación, borrado, copiado y cambio de 
"•z^bre de los archivos. 



AMBITOS DE UTILIZACION 
DE LOS ORDENADORES 



La incorporación del sistema operativo a la 
máquina, da pie al nacimiento de un orde- 
nador o sistema para el tratamiento de 
información. En su actuación práctica, 
éste puede operar en dos ámbitos funda- 
mentales, o lo que es lo mismo, de 
acuerdo a dos modos básicos de opera- 
ción: 

• En tiempo real o en 

• Explotación secuencia! por lotes. 

En el funcionamiento en tiempo real, el 
ordenador es capaz de generar una res- 




Las sistemas operativos disponen de todo un 
repertorio de herramientas de utilidad, 
destinadas a facilitar ai usuario el manejo de 
datos v programas: utilidades para la 
edición de órdenes, para la corrección de 
errores, para la apertura y actualización 
de archivos... 



puesta inmediata ante una acción o solici- 
tud externa. Por consiguiente, la relación 
entre el usuario y la máquina es interac- 
tiva. Este es el método más frecuente en 




La existencia de un amplio catálogo de traductores y programas 

de aplicación, es uno de los factores primordiales que intervienen en la 

evaluación de un sistema operativo. 
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La utilización de la máquina en tiempo real 
permite mantener una comunicación 
interactiva entre el usuario y el ordenador. 
Las órdenes introducidas por el 
tmtario son inmediatamente ejecutadas por 
el ordenador. 



el campo de los microordenadores: al in- 
troducir una orden, por ejemplo a "través 
del teclado, el ordenador la ejecuta de 
inmediato, entregando el resultado sin di- 
lación. En la explotación secuencial por 
lotes, la relación entre el usuario y 3a má- 
quina pierde su inmediatez; ya no se tra- 
baja en modo interactivo. El ordenador re- 
cibe un flujo de trabajos ("JOBs", en ter- 
minología inglesa) que irá procesando se- 
cuencialmente y sin una especial restric- 
ción de tiempo. Este método de explota- 
cíón tiene su manifestación más impor- 
tante en el denominado modo Batch. En 
un sistema utilizado en modo Batch, no es 
precisa la atención del usuario durante la 
ejecución de fos trabajos. Una vez que 
cada "job rr entra en tratamiento, el usua- 
rio pierde Ja posibilidad de intervenir y mo- 
dificar su desarrollo. Cuando ef usuario ne- 
cesita mantener un diálogo constante con 
la máquina, por ejemplo, para recibir 
ayuda del ordenador, debe optar por la 
actuación en modo interactivo. Por el con- 
trario, si la tarea a ejecutar está perfecta- 
mente estandarizada y puede realizarla la 
máquina sin intervención externa, el usua- 




En la explotación secuencial por lotes, la 
relación entre el usuario y la máquina deja 
de ser interactiva. El ordenador 
recibe un flujo de trabajos que irá 
procesando secuencialmente, sin exigir la 
intervención del usuario, 

rio puede liberar su atención y optar por el 
trabajo en modo "Batch". 
Ambos modos de actuación no se tradu- 
cen necesariamente en ordenadores dis- 
tintos. Los sistemas operativos actuales 
permiten a un mismo ordenador operaren 



S.Os. para ordenadores personales 



LA FAMILIA CP/M 

Éste fue el primer sistema operativo, de 
objetivo generalizado, que se desarrolló 
para su implantación en sistemas basados 
en microprocesador. Su creador, Gary 
Kildall, puso a punto una primera versión 
destinada al microprocesador 8003. 
Posteriormente se crearon nuevas y cada 
vez más evolucionadas versiones; las más 
relevantes son: 

• CP/M-80, para los microprocesadores 
8080 y Z-80; 

• CP/M-S6, para el 8086 y 8088; 

• Concurren t CP/H para 8086 y 8088; y 

• CP/M-68K, versión destinada al 
microprocesador 68000 de Motorola. 
El CP/M es el primero de los sistemas 
operativos generalizados que ha saltado del 
tradicional disco a la memoria ROM. En 
efecto, una de las últimas versiones es ef 
Personal CP/M, integrado en una memoria 
de sólo lectura y destinado a ordenadores 
personales de tipo doméstico. 
MP/M-80 y MP/M-86 son versiones para 
sistemas rnulti usuario creadas, 
respectivamente, para equipos de 8 y 

16 bits 

La mayor baza de esta popular familia de 
sistemas operativos reside en la 
voluminosa biblioteca de programas con 
que cuenta. 



MS DOS 

Hace algunos años r 3a firma Microsoft 
adquirió los derechos deJ MS/DOS por la 



discreta suma de cincuenta mil dólares. 
Poco más tarde, IBM optó por este sistema 
operativo para revestir su entrada en el 
mercado de los ordenadores personales El 

— ■ CPM-86 2% 

— ■ UNIX 2% 

OASIS 2% 

- - PICK 1% 

OTROS 47¿ 
P-SYS. 127o 
APPLE DOS 247* 
MS-DOS 297, 
CPM-80 587o 
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~odo interactivo o en modo Batch; la 
elección, en cada instante, la determina el 
: do de tarea, programa o aplicación a pro- 
:esar. 



QUE HAY QUE EXIGIRLE 
A ÜÑ S.O.? 



. na conclusión evidente es que la misión 
z Dbal del sistema operativo es gestionar 
z actividad del ordenador. Como tal ges- 
Dr, a la hora de enjuiciar su trabajo hay 
:je Gmpezar evaluando su eficacia. Esta 
es una exigencia que no puede determi- 
■5 se a partir de un criterio único, sino que 



L'no de los principales cometidos de 
zuaiquier sistema operativo es la protección 
_v ios recursos asignados a cada trabajo 
zonas de memoria reservadas, 
archivos de datos y programas...}. 



impacto del IBM-PC ha convertido al 
MS/DOS —rebautizado como PC/DOS en 
el IBM-PC — en un verdadero estándar; 
'levándolo al liderazgo de los sistemas 
operativos para microprocesadores de 16 
bits. Cada día son más los 
microordenadores que nacen con el 
marchamo de "compatibles IBM-PC", y 
tanto mayor os la difusión del MS/DOS y la 
amplitud de su biblioteca de programas de 
aplicación. 

Ai igual que el CP/Tvl-86, el MS/DOS está 
concebido para los microprocesadores 
8086 y 8088. Las últimas versiones del 
MS/DOS llegan a incorporar, incluso, un 
emulador de CP/M-86, lo que permite 
acceder a los archivos creados bajo el 
:ontrol de este sistema operativo. 
La variante multiusuario del MS/DOS es e! 
denominado XENIX; aunque, realmente, 
este no es más que una versión de otro de 
os populares: el sistema operativo UNIX. 
Otra variante del MS/DOS es el MSX/DOS, 
creado por Microsoft para equipar a los 
ordenadores domésticos adscritos al 
estándar MSX, 



LA FAMILIA APPLEDOS 

_a huella de la firma Apple, uno de los 
pioneros de la revolución micro informática, 
sigue aún en plena vigencia. Hasta tal punto 
que tras el CP/M y el MS/DOS, son los 



sistemas operativos Apple los que alcanzan 
una mayor cuota de difusión. 
Los equipos Apple II, incluidos los modelos 
más recientes Appfe He, Apple 'le ~s v 
Apple llc r incorporan todos ellos sucesivas 
revisiones del Apple. DOS: el sisiema 
operativo de la propia firma, cuyo producto 
más relevante es el DOS 3.3. 
Otros miembros de la familia son los 
sistemas operativos SOS — creado para el 
microprocesador Apple III— y el más 
reciente ProDOS. Este último, también 
creado para el microprocesador 6502 y 
compatible con los anteriores, goza de una 
notable aceptación entre los profesionales 
de la programación. 
A pesar de la exclusividad de estos 
sistemas operativos [sólo se encuentran en 
los microordenadores Apple y en los 
modelos compatibles de otras firmas), su 
difusión se mantiene en un nivel elevado, El 
motivo hay que buscarlo en la gran cantidad 
de programas de aplicación desarrollados 
en los últimos años para estos sistemas 
operativos. 

Tema aparte lo constituyen los nuevos y 
totalmente revolucionarios sistemas 
integrados, presentes en los modelos Lisa 
y Macintosh de la propia firma. 

UNIX 

Algunos sistemas operativos para 
microordenadores corresponden a 



migraciones procedentes del terreno de los 
microordenadores. Taf es el caso del UNIX, 
un sistema operativo multiusuario que 
soporta la operación en multitarea. 
El mayor número de incondicionales del 
UNIX cabe localizarlo entre el personal 
técnico y los programadores profesionales, 
debido a que su estructura dispone de 
excelentes útiles para el desarrollo de 
programas. 

El trasvase al campo de la micro informática 
se ha concretado sobre el microprocesador 
68000 de la firma Motorola. 
Por el momento, el UNIX parece reservado 
a los microordenadores más potentes, 
dotados de una gran capacidad de memoria 
y con una elevada velocidad de tratamiento. 



UCSO p-System 

Sus siglas corresponden a la Universidad 
Californiana de San Diego, en donde se 
desarrolló la versión original de este 
sistema operativo monousuario. 
La presencia de este sistema operativo es 
importante en el ámbito de la enseñanza 
informática. Los principales lenguajes que 
coexisten con el UCSD p- System, son el 
Pascal y el Fortran. Una de las versiones del 
Pascal, desarrollada por la propia 
Universidad de San Diego (el 
Pascal-UCSD) r encuentra su complemento 
idóneo en este sistema operativo. 
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SISTEMAS OPERATIVOS Y MICROPROCESADORES DE ALGUNOS 

ORDENADORES PERSONALES 



- ~ - — - - utf fiui l üiea 




País de origen 


Microprocesador 


Sistemas operativos 
incorpora bl es al 
equipo 




ft/lfi hiti 


AMSTRAD 


Amstrad 


Gran Bretaña 


Z80A 


g. 


CP/M 


APPLE DOS 


Apple Computer 


EE.UU. 


6502 


3 


ProDOS 1.02, DOS 3.3 


- = v - 


Commodore 


EE.UU. 


6510 


S 


Commodore DOS 


I = AGON64 


Eurohard 


España 


6809E 


8(1) 


OS9 


W 150 


Hewlett-Packard 


EE.UU. 


3088-2 


16 


MS-DOS 2.11 


ICLPC15 


ICL 


Gran Bretaña 


3085A 


8 


CP/M 


BM PC (y compatibles) 


IBM 


EE.UU. 


3088 


16 


PC/DOS, MS/DOS, CP/M-86 


MACINTOSH 


Apple Computer 


EE.UU. 


6S000 


16(2} 


Syst. Macintosh, SMALLTALK 


vsx 


Adscritos al estándar MSX 




Z80A 


8 


MSX/DOS, CP/M 


OUVETTI M20 


Olivetti 


Italia 


Z8001 


16 


PCOS 


PHILIPS P3500 


Philips 


Países Bajos 


Z80A 


S 


Turbo DOS 


RANK XEROX 820 II 


Rank Xerox 


EE.UU. 


ZSO 


3 


CPM 


RAIMEOW 100 


Digital Equ i p. Corp. 


EE.UU. 


Z80+8088 


8 16 


CP/M, MS/DOS 


SPECTRUM 


Sinclair 


Gran Bretaña 


zaoA 


8 


Propio 


TOSHIBA T3Q0 


Toshiba 


Japón 


8088 


16 


MS-DOS, CP/1V1-36 


WANG-PC 


Wang 


EE.UU. 


8086 


16 


MS-DOS, CP/M-86 



11) El 6809 es un microprocesador con una arquitectura adecuada para el tratamiento de palabras de 16 bits. 

2'i Dada su arquitectura rte^a. el 6BCÜU puece corr>irlor,-irr>c> corro un microprocesador capaz de operar tanto con palabras de 16 como de 32 bits. 



otras tareas o intentos de invasión proce- 
dentes de la periferia. 

— La versatilidad y eficacia del sisteme 
operativo se ven incrementadas en la me- 
dida en que brinda al usuario un mayo' 
repertorio de comandos y funciones. 

— La zona de memoria ocupada por e 
propio sistema operativo debe ser mí- 
nima, con objeto de que la mayor parte de 
los recursos de Ja máquina queden a dis- 
posición de los trabajos a realizar. 

Esta relación de criterios de idoneidad 
puede incrementarse con otras caracterís- 
ticas, complementarias aunque por ello no 
menos importantes; por ejemplo: 

— Es imprescindible que exista un am- 
plio catálogo de traductores de lenguajes 
y programas de aplicación compatibles 
con el sistema operativo Ello permitirá 
potenciar y dar versatilidad al ordenador, 

— Un buen sistema operativo debe estar 
diseñado para hacer frente a muy diversas 
contingencias sin perder su eficacia. Si su 
estructura es modular, la inducción de un 
error en un módulo no debe tener efecto 
en los demás. 

— Es conveniente que el sistema opera- 
tivo sea abierto, en orden a facilitar su 
mantenimiento y actualización. 

No cabe duda que la potencia y eficacia 
del ordenador depende de algo más que 
de la arquitectura de la máquina. La inter- 
vención del sistema operativo es de total 
importancia a la hora de precisar las posi- 
bilidades del ordenador y establecer sus 
límites de utilidad práctica. 



debe conjugar satisfactoriamente todo un 
cúmulo de características; algunas depen- 
dentes de la propia arquitectura del orde- 
nador que aloja al S,0. Si precisamos 
nuestra atención sólo en el sistema opera- 
tivo — omitiendo los condicionantes que 
impone el hardware de la máquina — , su 
"eficacia" dependerá de que se aproxime 
en mayor o menor grado a características 
como las que enunciamos a continuación: 

— Un buen sistema operativo debe apro- 
vechar a] máximo las posibilidades hard- 
ware del ordenador. 

— Durante su actividad debe lograr que la 
unidad central de proceso opere con un 
rendimiento máximo. En consecuencia, 
ésta debe permanecer inactiva el menor 
tiempo posible. 



— Si la actuación es en modo interactivo, 
la gestión del S.O. debe ser tal que el 
diálogo ordenador usuario sea rápido: las 
respuestas deben fluir inmediatamente 
de la máquina 

— La asignación de recursos debe ser 
óptima: distribución idónea de la memo- 
ria, gestión rápida y eficaz de los periféri- 
cos. 

— La velocidad de tratamiento debe ser 
lo más elevada posible; por ejemplo, a la 
hora de ejecutar trabajos en modo Baten. 

— Debe ofrecer al usuario una informa- 
ción completa y detallada del estado del 
sistema en cada instante: directorios de 
archivos, mensajes de ayuda... 

— Debe proteger tos recursos asignados 
a cada trabajo (zonas de memoria reserva- 
das, archivos,,.) frente a invasiones de 




La importancia de los equipos Apple en el mercado actual, {¡ene su reflejo en el ele 
número de usuarios de los sistemas operativos específicos de esta firma. 



-¿ido 
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Software vertical y horizontal 

De las aplicaciones específicas, a los 
paquetes estandarizados 



on varios los criterios que in- 
tervienen a la hora de decidir 
cuál es el ordenador idóneo. 
No obstante, el camino hacia 
decisión parte, habitualmente, del con- 
jnto de tareas que es preciso automa- 
ar. 

na vez precisadas con toda suerte de 
etaíle las características que van a exi- 
girse a cada aplicación, [lega el primer in- 
terrogante: ¿existe en el mercado algún 
z-ograma o paquete de programas que 
satisfaga las condiciones impuestas? 



Los programas que desarrollan un juego 
\rman parte del software vertical. Su 
¿ct i vi dad es educar al ordenador para que 
'cálice u na tarea específica. 






DEBE 



HABER 



ABOGADO 




CAJA 



SOFTWARE VERTICAL 
Y HORIZONTAL 



La respuesta hay que buscarla en los dos 
bloques primarios en los que se divide el 
software de aplicación: software vertical y 
horizontal. 

Software vertical 

Esta categoría engloba a los programas y 
paquetes creados para resolver una tarea 
específica. Por ejemplo, forman parte del 



El software vertical acoge a los programas y 
paquetes creados para resolver una 
aplicación específica: programas para 
automatizar el ejercicio de ana actividad 
pro fe sion al (m éd u k os , a bogados , 
arquitectos.. .), o para resolver una tarea 
especializada (diario de caja, contabilidad 
general... e incluso juegos). 
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software vertical los paquetes de aplica- 
ción diseñados para automatizar la activi- 
dad que rodea al ejercicio de una profe- 
sión: médico, abogado, arquitecto... O 
para e! tratamiento de un trabajo especí- 



fico: confección de la nómina de una em- 
presa, gestión de la actividad de un video- 
club, o automatización de la puesta en 
práctica del Plan General contable en una 
empresa. 

Software horizontal 

El contrapunto del software específico o 
vertical, se encuentra en los paquetes ca- 
paces de resolver un gran número de apli- 
caciones dentro de un determinado 



marco de actividad. Este tipo de progra- 
mas y paquetes de aplicación general 
constituye el denominado software hori- 
zontal 

A este grupo pertenecen las herramientas 



de gestión y productividad: tratamientos 
de textos, hojas electrónicas, programas 
para la gestión de bases de datos, paque- 
tes para la creación de gráficos, progra- 
mas para el establecimiento de comunica- 
ciones externas al sistema... 
Todos comparten la característica de que 
el usuario puede orientarlos a cada nece- 
sidad específica, dentro del abanico de 
posibilidades que brinda cada paquete ho- 
rizontal. Así, por ejemplo, la hoja electró- 
nica es útil tanto al odontólogo, al que 



facilitará el cálculo de la minuta, como e 
economista, quien lo utilizará para deter- 
minar el precio de venta al público de jf 
producto en función de los costes de pro- 
ducción. 

De las cinco categorías en las que suele 
clasificarse el software de aplicación: 

• Juegos/Entretenimiento 

• Educación 

• Herramientas de gestión y producti- 
vidad 

• Científico-técnicos 

• Contabilidad y administración; 

el software vertical predomina en todas 
ellas, excepto en las "herramientas de 
gestión y productividad", categoría en ls 
que se encuentra el núcleo de los progra- 
mas y paquetes generalizados u horizon- 
tales. 

Al margen de los programas estandariza- 
dos presentes en los canales comerciales, 
se encuentra el software confeccionado 
"a medida 11 , adecuado para satisfacer un 
trabajo altamente específico. Dada su 
concreción, es obvio que los programas 
J a medida" hay que encuadrarlos, nor- 
malmente, en el marco del software ver- 
tical. 



ORDENADORES PERSONALES 
PARA CUALQUIER APLICACION 



En el mundo de los ordenadores persona- 
les caben muy diversos tipos de equipos, 
desde simples ordenadores de bolsillo 
(como el popular ZX-31), u ordenadores 
domésticos (ZX-SPECTRUM, VIC-20, 
DRAGON, ATARI, COMMODORE 64, 
ORIC, hasta potentes ordenadores de 
gestión (IBM-PC, HP-150, NCR, DMA/...). 
De acuerdo con la naturaleza del ordena- 
dor personal, éste será capaz de acometer 
trabajos más o menos complejos. Este es 
un factor que se manifiesta en el mercado 
de las aplicaciones- La biblioteca de pro- 
gramas disponibles para ordenadores do- 
mésticos se inclina hacia ciertas catego- 
rías del software de aplicación; una biblio- 
teca muy distinta de la creada para tos 
ordenadores de tipo profesional o de ges- 
tión. 





Los programas y paquetes de tipo horizontal resultan adecuados para resolver un gran número 
de aplicaciones dentro de un determinado marco de actividad. 
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En eí caso de los ordenadores domésti- 
cos, la mayor profusión de programas co- 
rresponde al apartado de juegos y entre- 
tenimiento. Aunque, también existen pro- 
gramas, de moderada complejidad, que 



A f igual que los restantes elementos 
software del ordenador, los programas y 
paquetes de aplicación se alojan en las 
unidades de memoria. Su misión es la de 
almacenar la información que utiliza la 
maquina, tanto programas como datos. 
En el ordenador cabe distinguir dos tipos de 
memorias o unidades para el 
almacenamiento de información: Ea 
memoria central o residente en la máquina 
y las memorias de masa; estas últimas, 
independientes de la unidad central y 
asociadas al equipo externamente. 
La actividad de cálculo y proceso directo 
tiene lugar con la información que, en cada 
instante, reside en Ja memoria central del 
ordenador Si bien, esta zona de 
almacenamiento interno sólo es capaz de 
memorizar un volumen de información 
limitado. 

Las unidades de memoria de masa, 
externas al ordenador, elevan el vo fumen 
de información af que puede acceder el 
ordenador y, en consecuencia, hacen que 
su actividad de tratamiento pueda alcanzar 
una mayor potencia y versatilidad. En 
cualquier caso, no hay que perder de vista 
que el ordenador sólo puede procesar 
directamente fa información almacenada en 
su memoria central Por ¡o tanto, a fa hora 
de ejecutar un programa o procesar unos 
datos alojados en la memoria externa, debe 
empezar trasladando la mencionada 
información a su memoria central Una vez 
realizado el tratamiento oportuno, 
devolverá Ja información puesta en juego a 
su emplazamiento habitual en la memoria 
de masa. 

A fa hora de adquirir ef software de 
aplicación, ef usuario se encontrará con que 
éste se encuentra almacenado en un 
soporte de memoria; cinta de tipo cásete, 
cartucho de memoria ROM o disco ffexíbfe, 
p ara que el ordenador pueda ejecutar fa 
aplicación es necesario, pues, ponerla a 
disposición del mismo, introduciendo el 
soporte de fa aplicación en la 
correspondiente unidad de memoria que 
estará asociada a la máquina- 
Cada soporte de memoria tiene sus propias 
características que determinan su 



permiten al usuario editar su correo per- 
sonal, gestionar ía agenda telefónica y 
manipular los archivos personales, gestio- 
nar la contabilidad doméstica o colaborar 
en labores educativas. 




idoneidad en cada caso específico. Por 
ejemplo, fa cinta de tipo cásete está 
prácticamente reservada a Jos ordenadores 
domésticos. Su reducida capacidad y 
lentitud, descartan su empleo como 
memoria de masa de ordenadores de 
gestión, destinados a tareas complejas. No 
obstante, su precio moderado convierte a 
fas casetes en soportes adecuados para 
aplicaciones de juegos, educativas o 



Existen incluso algunos programas hori- 
zontales que corresponden a versiones 
simplificadas de los paquetes habituales 
en los ordenadores personales más evolu- 
cionados: hojas electrónicas, tratamien- 

1 

íncfuso de gestión a baja escala, destinadas | 
a ordenadores domésticos. 
El cartucho de memoria ROM es una 
alternativa a las cintas de tipo cásete en el 
terreno de los ordenadores domésticos. 
Aunque es un soporte más caro que la 
cinta, ef acceso a fa información 
almacenada es casi instantáneo, lo que i 
convierte al cartucho en un medio de 
almacenamiento más práctico, Ef óbice que 
impide su uso habitual como soporte para 
a pfica cienes más complejas es su e (evado 
precio y moderada capacidad, además de 
que sólo permite la lectura de la 
información afmacenada, 
Ef disco flexibfe es el soporte habitual de fas 
aplicaciones destinadas a ordenadores 
personales de tipo profesional o de gestión. 
Los formatos normalizados de los discos 
flexibles son 8 pulgadas ó 5 y 1/4 pulgadas; 
sin olvidar a los más recientes 
micro-floppies, cuyos tamaños más 
frecuentes son 3 ó 3 y 1/2 pulgadas. Dentro 
de los discos magnéticos cabe una 
categoría especial: los discos rígidos. Su 
uso como memoria de masa es cada vez 
más habitual en ios ordenadores 
personales, dada su alta capacidad de 
almacenamiento y velocidad de acceso a la 
información, No obstante, hay que tener en 
cuenta que son discos fijos, no extra toles 
de la unidad que gestiona su grabación y 
lectura. 




Los soportes de memoria del 
software de aplicación 
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TRATAMIENTO 

I DE ! 

I TEXTOS_! 



I GESTION H 
DE 

L ARCHIVOS J 





Herramientas 
de 

Gestión 

y 

Productividad 







GRAFICOS 


\ 












Las herramientas de gestión y productividad dominan el mercado del software horizontal. Su 
presencia es habitual junto a ordenadores personales de tipo profesional o de gestión- 





Las hojas electrónicas y los programas para el tratamiento de textos son dos representantes 
clásicos popularizados del software horizontal. 



tos de textos, gestores de bases de datos La mayor potencia y capacidad de la fami- 
o programas para fa confección de grá- lía de Eos ordenadores personales se en- 
f icos. cuentra en los equipos profesionales, por- 



tátiles o de sobremesa, y en los orienta- 
dos a tareas de gestión. El surtido de apli- 
caciones para estos ordenadores se de- 
canta hacia los paquetes verticales, desti- 
nados a profesionales o a pequeñas y me- 
dianas empresas, y hacia las herramientas 
de gestión y productividad. Esta última < 
la categoría del software horizontal que 
goza de un repertorio más dilatado de pro- 
gramas. 

HERRAMIENTAS DE GESTION 
Y PRODUCTIVIDAD 



El mercado del software horizontal está 
dominado por un conjunto de paquetes de 
aplicación, destinados a actividades de 
gestión y productividad. Paquetes de pro- 
gramas capaces de prestar un eficaz 
servicio en un dilatado abanico de situa- 
ciones. 

A esta gama de herramientas software se 
debe, en gran parte, el vertiginoso empuje 
comercial de los paquetes estandariza- 
dos. De su importancia aboga el hecho de 
que la adquisición de un ordenador perso- 
nal, ya sea para uso profesional o para la 
gestión en el ámbito de fa empresa, suele 
simultanearse con la de algún paquete de 
esta categoría. 
El conjunto de herramientas de gestión y 
productividad se divide en vahos grupos o 
áreas de actividad: 

• Tratamiento de textos 

• Hojas electrónicas 

• Gestión de archivos y bases de datos 

• Paquetes gráficos 

• Paquetes de comunicación. 

Cinco grupos básicos que pueden com- 
pletarse con otros de menor relevancia 
como, por ejemplo, los paquetes para la 
generación de programas, o los modernos 
gestionadores de tiempo, ideas, tareas y 
proyectos. 

El predominio se encuentra, sin lugar a 
dudas, en los cinco primeros grupos. Den- 
tro de cada uno de ellos se encuentran 
paquetes de programas cuya denomina- 
ción (Wordstar, Multiplan, Visícalc, dBASE 
II...) tiene mayor notoriedad en el mundo 
informático que el propio nombre de mu- 
chos ordenadores. 
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Operando con el BASIC 

LIST y REM: dos comandos 
para auxiliar al programador. 
Los operadores aritméticos elementales 



Los ordenadores son, en esen- 
cia, máquinas concebidas para 
almacenar y procesar informa- 
ción. El concepto de informa- 
ción relativo a los ordenadores tiene algo 
que ver con fa aceptación coloquial de 
este término. 

En general, información es todo aquello 
que incrementa nuestro conocimiento. 
Trasladándolo al caso del ordenador, el 
concepto de información es aplicable a 
iodo aquel material que se suministra a la 
máquina, ya sea para instruirla (coman- 
dos, órdenes, instrucciones, programas) o 
para que ésta fo opere y manipule de 
acuerdo a las indicaciones que reciba. 
Es evidente que la distinción señalada 
equivale a dividir la información en dos 
categorías: los datos, que pueden ser nú- 
meros, letras, palabras,,,, y los programas 
o conjuntos de instrucciones que indican 
al ordenador la tarea a realizar. 
Toda esta información ha de quedar al 
alcance de la máquina para que le sea 
oosible utilizarla en el momento ade- 
cuado. Def almacenamiento de la misma 
se ocupan las unidades de memoria, ya 
sean residentes en el corazón del ordena- 
dor y a disposición directa e inmediata de 
a unidad centra! de proceso, o asociadas 
como dispositivos externos a la máquina, 
^a confección de programas —informa- 
ción destinada a "instruirá la máquina" — 
es, precisamente, el objetivo práctico de 
os lenguajes de programación. Estos de- 
sen aportar el vocabulario adecuado para 
expresar cualquiera de las acciones habi- 
tuales; además, deben ofrecer al usuario 
-~ surtido de órdenes que faciliten la con- 
fección de programas. Dentro de este úl- 
"jmo grupo se encuentran dos comandos 
BASIC que se van a exponer a continua- 
ción: LIST y REM. 



EL COMANDO LIST 



Una necesidad obvia del programador, es 
la de ver en cualquier momento e 1 resul- 
tado de su trabajo. En definitiva, obtener 
en la pantalla una lista ordenada de las 
instrucciones que ha ingresado en el or- 
denador para construir un programa. 
Ta] posibilidad la ofrece el comando LIST. 
, Este permite visualizar (LISTarl el pro- 
agrama almacenado en memoria en ese 
¡preciso instante. 

Pero no radica ahí la solución de todo el 
problema... ¿Qué sucede cuando el pro- 
grama es suficientemente grande como 
para no poder visualizarlo en el espacio 
que ofrece una sola pantalla? Para solucio- 
nar este inconveniente, e¡ ce— s^co LIST 
ofrece toda una serie de opciones que 



permiten el cómodo examen :t z~ 
grama a través de fa pantalla. 
Las instrucciones LIST, cuyo fonrssic as- 
nera-I es: 

LIST [<Número de línea> [-[<"• -~-e--: 
de línea>]]] 

permiten "listar", total o parcia w -~~- - 
programa que se encuentra almacenado 
en ta memoria del ordenador. 
Las distintas opciones que ofrece e ri- 
mando, pueden ser selecciona-i — r- 
diante la inclusión o no de los es - " 
opcionales a los que hace re'e t : . : 
formato general. 

Para estudiar las distintas modalidades ife 
instrucciones que pueden consta -s-e : : - 
el comando LIST, se utilizará ~ i ~ : 
programa ejemplo, cuyo listado cor~o-e^ 
es el que aparece a continuación 

10 PRINT "INSTRUCCIONES" 
20 PRINT "LIST:" 
30 PRINT "ESTO NO ES 
40 PRINT "MAS QUE UN" 
50 PRINT "EJEMPLO" 
60 ENO 



{ 



IKPORMACIOEr 




En esencia, los ordenadores son máquinas concebidas para almacenar y procesar utfbnmmM 
En el caso del ordenador, el concepto de información es aplicable a iodo aquel 
material que se suministra a la máquina, ya sea para instruirla (órdenes, insinu é; 
programas} o para que proceda a su tratamiento (datos). 



i- 



Basic 



Si el número de línea va seguido por un 
guíón H se listará fa mencionada línea y to- 
das ¡as restantes que tengan un número 
superior al indicado. Esto es: se mostrará 
en la pantalla la zona del programa que va 
desde la línea señalada tras ef comando 
LIST hasta el final del mismo: 




La primera de las instrucciones a la que da 
pie el uso de este comando consta, senci- 
llamente, del comando LIST aislado, omi- 
tiendo la zona de argumento. La res- 
puesta del ordenador será la presentación 
del programa completo, listado a partir del 
número de línea inferior, 
En el caso de que el programa que se 
encuentra en la memoria sea e! propuesto 
en el párrafo anterior, el efecto de la orden 
LIST será el siguiente: 



El objetivo de ios lenguajes de programación 
es construir programas: secuencias 
ordenadas de instrucciones capaces de 
«educar» ai ordenador para que realice un 
determinado trabajo. 



Una primera alternativa es introducir 
como- argumento un soto número de lí- 
nea. La respuesta de la máquina será la 
visualizaron exclusiva de tal línea; por 
ejemplo: 



Por el contrario, si el guión precede al 
número de líneas especificado, se listará 
el programa desde el principio hasta llegar 
a ese número de línea. Por ejemplo: 





Una nueva variante de la instrucción LIST 
es la que incluye en el argumento dos 
números de línea, separados por un 
guión. En tal caso, se listarán todas las 
líneas del programa cuyo número esté 
comprendido entre ambas. Esta última 
opción resulta útil para presentar en pan- 



Como se observa, el ordenador muestra 
todas y cada una de las líneas del pro- 
grama. 

También es posible "listar" tan sólo parte 
del programa. Para ello, hay que especifi- 
car en el argumento de LIST fa línea o las 
lineas deseadas. 




Presenta en pantalla las líneas del programa almacenado en memoria. 

Formato: L\ST[< número de línea >[-[<número de línea >]]] 

Ejemplos: LIST 

LIST 3-100 
LIST -200 
LIST 50- 
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a sólo determinados bloques o zonas 
;! programa en curso. 



LIST 20-40 



20 PRINT 
30 PRINT 
40 PRINT 



"LIST:" 
ESTO NO ES " 
MAS QUE UN' 





Hay que indicar que este comando per- 
mite listar cualquier programa almace- 
nado en la memoria del ordenador. Si 
bien, es preciso que el programa en cues- 
tión esté escrito en BASIC. Esta salvedad 
se refiere al hecho de que LIST no resulta 
adecuado para listar un programa escrito 
en código máquina, ni desde luego un 
escrito en cualquier otro lenguaje. Este 
último caso es manifiestamente imposi- 
ble, ya que, probablemente, la mácula ni 
tan siquiera reconocerá el comando. 
Tras la ejecución del comando LIST, el 
BASIC regresa al modo directo. Ello signi- 
fica que sí se introduce tal comando en 




¿Qué es y qué no es un ordenador personal? 



Cualquier ordenador, sea cual fuere su 
tamaño y potencia, es un producto de la 
síntesis de dos elementos 
complementarios: un soporte físico o 
circuito electrónico, el «hardware», y una 
programación o conjunto de instrucciones, 
datos, programas..., el «software». Ambos 
elementos se conjugan en un sistema para 
el tratamiento de información u ordenador. 
Aquí aparece la distinción esencial entre el 
ordenador y otras máquinas capaces sólo 
de resolver un determinado número de 
tareas especificas (una calculadora, por 
ejemplo). El ordenador es un sistema cuya 
funcionalidad no está predefinida por su 
estructura física, sino que puede ser 
instruido» por el usuario para realizar una u 



otra función introduciéndole un programa al 
efecto. 

Una calculadora convencional es cacaz ce 
realizar ciertas operaciones matemáticas 
(suma, resta, multiplicación, división...), 
pero única y exclusivamente esas 
operaciones preestablecidas. Por su parte, 
el ordenador posee un campo de aplicación 
totalmente versátil, definible en cualquier 
instante por medio del adecuado programa. 
Puede realizar cálculos complejos en los 
que intervengan secuencias de 
operaciones, comparaciones y decisiones, 
y su efectividad no se limita a los cálculos 
matemáticos, sino que se extiende a 
cualquier aplicación definible como 
tratamiento de información sea ésta de 




VIDEOJUEGOS 



SU PER - 

ORDENADOR 



naturaleza simplemente numérica O 
alfanumérica. 

La diferencia del ordenador con otras 
máquinas más sofisticadas y que, en 
muchos casos, incorporan en su interior un 
microprocesador, es ya más sutil. Las 
consolas de video-juegos constituyen un 
perfecto ejemplo de equipo dotado de una 
unidad central de proceso integrada (un . 
microprocesador), y capaz de ejecutar un 
programa (el cartucho de juego). En este 
caso, la distinción básica reside en que 
tales máquinas siguen encerradas dentro 
de un marco de aplicación específico: la 
ejecución de juegos sobre una pantalla. No 
están abiertas a lenguajes de programación 
que versátil icen sus posibilidades, y 
tampoco disponen de un sistema operativo 
que ponga toda su potencialidad en manos 
del usuario. 

Una vez delimitado el terreno de los 
ordenadores o máquinas programabas 
para el tratamiento de la información, llega 
el momento de caracterizar al ordenador 
personal. 

No hay que olvidar a los grandes 
ordenadores y tampoco a los 
míniordenadores, e incluso a los 
microordenadores evolucionados. 
Aunque cada vez son mayores las 
intersecciones entre las diversas 
categorías de ordenadores, puede 
enmarcarse al ordenador personal en una 
zona propia. Dentro de un ámbito 
delimitado por su definición más amplia: 
máquina programadle basada en 
microprocesador, destinada al tratamiento 
de información y orientada al usuario 
individual; con una gama de periféricos, 
sistemas operativos, lenguajes de 
programación y programas de aplicación 
concebidos específicamente para su 
explotación. 
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Una de las características propias de ¡os lenguajes de programación es la de brindar al 
programador herramientas para facilitar su trabajo. LIST y REM son dos de (os comandos que 
ofrece el BASIC para ente cometido. 



forma de instrucción indirecta dentro de 
un programa, la ejecución del mismo se 
detendrá tras listarlo. Un ejemplo de la 
actuación del comando LIST utilizado a 
modo de instrucción indirecta, lo aporta e! 
siguiente programa: 

10 PRÍNT "LIMITACIONES DEL LIST" 
20 PRINT "ESTA LINEA SI SE EJECUTA" 
30 LIST 

40 PRINT "ESTA LINEA NUNCA SE 

EJECUTARA" 
50 END 

En efecto, ta ejecución se detiene al pro- 
cesar la instrucción LIST: el ordenador 
presenta el listado del programa y, acto 
seguido, abandona la secuencia de ejecu- 
ción para pasar a modo directo o situación 
de diálogo: 

RUN 

LIMITACIONES DEL LIST 

ESTA LINEA SI SE EJECUTA 

10 PRINT "LIMITACIONES DEL LIST" 

20 PRINT "ESTA LINEA SI SE EJECUTA" 

30 LIST 

40 PRINT "ESTA LINEA NUNCA SE 

EJECUTARA" 
50 END 



La actividad del ordenador 



¿Para qué sirve un ordenador? Este es uno 
de los primeros interrogantes que surgen al 
tomar un primer contacto con ei mundo de 
la informática. La respuesta no deja de 
resultar problemática por su difícil 
concreción. EJ motivo radica en que un 
ordenador puede hacer, o por lo menos 
ayudar a hacer, casi todo; siempre que 
cuente con el programa adecuado y con el 
apoyo de los periféricos idóneos. 
A la hora de adquirir una idea real de lo que 
cabe esperar de un ordenador, es muy 
conveniente empezar conociendo cómo 
trabaja. Para eílo r resulta ilustrativo 
comparar la actividad de la máquina con el 
trabajo cotidiano en la oficina de facturación 
de una empresa. 

La oficina está situada en una habitación 
provista de dos ventanillas, una de 
recepción o entrada y otra de salida. El 
empleado necesita tener a mano el 
conjunto de normas que detallan su trabajo, 
así como los datos necesarios para realizar 



cada tarea. Para ello dispone de un tablero, 
donde coloca el albarán que contiene los 
datos de entrada. Este albarán incluye el 
nombre del cliente con el que se efectúa la 
operación, así como el tipo de artículos y la 
cantidad de los mismos. 

Sobre el tablero también hay un folleto con 
la tarifa de precios vigente y con 
información sobre los descuentos a aplicar 
a cada cliente. Ai lado de estos datos se 
encuentra la lista de normas a seguir para 
realizar el trabajo. Algo semejante a un 
programa cuyas instrucciones detallan, 
paso a paso, las operaciones a poner en 
práctica. Como herramienta de cálculo, el 
administrativo dispone de una pequeña 
calculadora. 

Dado el volumen de Ja información puesta 
en juego, es posible que el espacio 
disponible en el tablero sea insuficiente. 
Por esta razón el operario dispone de un 
archivo localizado en una habitación 



contigua. En este almacén residen Jos 
ficheros que guardan la Información que no 
es posible mantener en el tablero por falta 
de espacio. 

En resumidas cuentas, eJ administrativo 
lleva al tablero, exclusivamente, la 
información necesaria para ejecutar una 
parte del trabajo. Cuando necesita más 
datos, por haber concluido esa parte del 
trabajo o porque los datos no son ya los 
adecuados, actualizará la información 
adherida al panel. Esta es una situación 
parangonable con la actividad y con el 
método de trabajo habitual en un 
ordenador. Cada uno de los elementos 
descritos tienen su homólogo en la 
máquina. 

La ventanilla de recepción equivale al 
órgano para entrada de información 
(normalmente, el teclado) de! ordenador. El 
administrativo, rodeado de sus 
herramientas operativas (papel, lápiz, 
calculadora.. .} gestiona el tratamiento de la 
información; tarea ésta encomendada a la 
unidad centra! de proceso del ordenador (el 
microprocesador, en el caso de un 
ordenador personal). 
El pane! tiene su reflejo en la memoria 
central del ordenador, en la que se 
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MEMORIA : 
















¡LISTADO) 



función del comando LIST, en sus distintas formulaciones, es presentar en la pantalla un listado total o parcial del programa en car so 
nace nado en la memoria del ordenador. 



- ^ecibir la orden RUN, el ordenador ha 
■ : a do la ejecución del programa, cur- 
ando la tarea ordenada en las instruccío- 
es 10 y 20. Al llegar a la línea 30 r la 
máquina ejecuta la instrucción LIST, mos~ 
■sido en pantalla el listado completo del 
rograma... y, acto seguido, se detiene 
-cstrando el cursor. Las líneas 40 y 50 
Ladan sin ejecutar, debido a que fa ins- 
"_::ión LIST (línea 30) obliga al intérprete 
Ca abandonar la ejecución en curso 
a ^egresar a modo directo. 



EL COMANDO REM 



A primera vista, la presencia de este co- 
mando dentro del vocabulario de un len- 
guaje de programación, puede parecer un 
despropósito. REM es un comando que 
no tiene efecto alguno en la ejecución de 



un programa BASIC, hasta el punto de 
que es ignorado por el ordenador. No obs~ 
tante, en determinados casos, su presen- 
cia dentro de un programa llega a ser casi 
esencial. La misión del REM (del inglés: 
REMARK, Comentario) es introducir co- 
mentarios en el programa que faciliten su 
interpretación posterior por parte del pro- 
pio programador o de otros usuarios.. En 
programas cortos su empleo es casi su- 
perfluo, ya que con un simple vistazo se 
puede saber cuál es el cometido del pro- 



i "nace na n los datos y programas en curso 
ejecución. Este cuenta con el auxilio de 
jr\ archivo de gran capacidad, al que se 
raslada o del que se extrae la información 



de trabajo: la memoria de masa del 
ordenador. 

Por último, el resultado del trabajo 
acometido, la factura dirigida a c e r te. 



abandona el recinto a través de la ventanilla 
de salida. Una imagen paralela al órgano de 
salida del ordenador (por ejemplo, la 
pantalla de visualrzación), 
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Introduce un comentario en el programa. Este comando y el texto que le sigue no se 
ejecutan. 

Formato: (Número de línea) REM [<comentario>] 

Ejemplos: REM 

REM ESTO ES UN COMENTARIO- 
REM PROGRAMA 56- B 




grama y la función de las variables em- 
pleadas. No obstante, cuando el programa 
sea un poco largo y complicado, su pre- 
sencia resultará providencial. Sí no se in- 
troducen comentarios explicando la fun- 
ción de cada parte del programa y e! co- 
metido de las distintas variables, ni af 
mismo programador que lo ha diseñado le 
resultará fácil revisar su estructura e intro- 
ducir nuevas modificaciones en tal pro- 
grama, transcurrido un cierto tiempo 
desde su confección. 

10 REM PRINCIPIO DE LA ZONA DE CALCULO 
20 REM PROGRAMA REVISADO EL 10 DE 
OCTUBRE 

30 REM LA VARIABLE P CONTIENE EL PRECIO 
EN DOLARES 

Como se observa en el ejemplo, el for- 
mato del comando REM es de lo más 
simple. Basta con empezar la instrucción 
con la palabra REM y añadir a continua- 
ción el texto del comentario. 
En algunas versiones del lenguaje BASIC, 



es posible sustituir la palabra clave REM, 
por un simple asterisco (*), por un apos- 
trofe ('}, por un signo de admiración (!) o 
por cualquier otro símbolo específico. 

OPERADORES ARITMETICOS 



Sin lugar a dudas, un ordenador desde 
luego es mucho más potente que una 



calculadora. En principio, puede compartir 
todas las posibilidades de una calcula- 
dora: desde las operaciones aritméticas 
elementales hasta cálculos en los que in- 
tervengan funciones trigonométricas y al- 
gebraicas 

A pesar de ello, hay que señalar que 
eí modo de operación no acostumbra a 
ser tan inmediato como el propio de una 
calcufadora. No hay que perder de vista 
que, en el caso del ordenador hay que 
ajustarse a las reglas de sintaxis y ortogra- 
fía propias del lenguaje de programación 
utilizado; del BASIC en nuestro caso. 

Las operaciones matemáticas básicas 
realizadas por un ordenador, instruido con 
el lenguaje BASIC, coinciden con las habi- 
tuales en una calculadora: suma, resta, 
multiplicación, división y potenciación. 

Los signos u operadores asociados a cada 
una de las citadas operaciones son los 
que muestran la tabla adjunta. 

En el lenguaje BASIC los operadores arit- 
méticos se utilizan para establecer relacio- 
nes matemáticas entre los datos, dentro 
del argumento de las instrucciones. 

Este cometido es extensivo a los dos mo- 
dos básicos de formulación de las instruc- 
ciones: directo [sin número de línea) e indi- 
recto {con número de línea, formando 
parte de un programa). Naturalmente, uti- 
lizando instrucciones directas, que obtie- 
nen del ordenador una respuesta inme- 
diata, puede simularse el funcionamiento 
propio de una calculadora. Por ejemplo: 




Operación 


Comentario 


Ejemplo 


Resultado 


+ 


suma 


6-H4 


10 




resta 


3-8 


-5 


* 


multiplicación 


5*7 


35 


/ 


división 


3/4 


2 


A Ó | 


potenciación 


6 f 3 


216 
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TABLA DE CONVERSION 



ORDENADOR 


LIST 


REM 


LIST 


LIST ni 


LIST -ni 


LIST nl- 


LIST nl1-nl2 


REM 


Signo equiva- 
lente 


iPPLE II (APPLESOFT) 


LIST 


LIST ni 


LIST r nl 


UST nl, 


U ST nH;nl2 


REM 


— 


APRICOT (M9BASIC) 


LIST 


LIST ni 


LIST -ni 


UST nl- 


LIST nl1-n!2 


REM 




ATAR1 


LIST 


LIST ni 


LIST ni 


LISTnt 


LIST nl1,nl2 


REM 




C8 M 64 


LIST 


LIST ni 


LIST -ni 


UST nl- 


LIST n1t-n!2 


REM 




DRAGON 


LIST 




LIST -ni 


LIST n - 


LIST nl1-nl2 


REM 




EQUIPOS MSX 


LIST 


LIST ni 


LJST -ni 


LIST nl- 


UST nll-nl2 


REM 




HP-150 


LIST 


LIST ni 


LIST -ni 


LIST nl- 


LfST n11-nJ2 


REM 


Signo equi- 
valente 


BM PC 


LIST 


LIST ni 


LIST -ni 


LIST nl- 


LIST nl!-nl2 


REM 


Signo equi- 
valente 


j MPF 


LIST 


LIST ni 


LIST -ni 


LIST nl. 


LIST nl1,nl2 


REM 




NCR DM-V (MS-BASIO 


LIST 


LIST ni 


LIST -ni 


LIST nl- 


LIST nll— n!2 


REM 




NEW BRAIIM 


LIST [-] 


LIST ni 


LIST -ni 


LIST nl- 


LIST nl1-nl2 


REM 




DRIC 


LIST 


LIST ni 






LIST n!1-ní2 


REM 


Signo equi- 
valente 


SHARP MZ-700 (MZ-BASIC) 


LIST 


LIST ni 


LIST -ni 


. LIST nl- 


LIST nl1-n!2 


REM 




SINCLAIR QL 


LIST 


LIST ni 


LIST TO ni 


LIST nl "0 


LIST nll TO nl2 


REMark 




SPECTRA VIDEO 


LIST 


LIST ni 


LIST -ni 


LIST nl- 


LIST nl — nl2 


REM 




2X-SPECTRUM 


LIST 






UST nl 




REM 





«i = Número de línea, nll = Número de línea inicial, nl2 = número de fínea final. 

FORMULACIONES DE LOS COMANDOS 

Lista el programa completo. LIST nl: Muestra en pantalla de línea solicitada. LIST-nl: Presenta las línoas del programa comprendidas desde la 
- ara hasta la especificado. LfST nl-: Lista desde la línea indicada hasta el final del programa. LIST nll -nl2: Muestra las líneas del programa 
^reprendidas entre las dos especificadas, ambas incluidas. REM: Introduce un comentario en el programa. La presencia de esta instrucción es 
ero rada por el ordenador durante la ejecución. Signo equivalente: Signo que puede sustituirá la palabra comando REM, 



- sulta obvio que para obtener la visuali- 
23dón de los resultados, hay que apo- 
rse en Instrucciones de tipo PRINT, Su 
; _mento es el que servirá para definir la 
□Deración a realizar. 

lesde luego, es posible definir operacio- 
~~s combinadas en las que intervengan 
i^os datos y operadores. 
z empleo de varios operadores aritméti- 
:os dentro de una misma expresión se 
~ce por las siguientes normas: 

• dentro de cada expresión las operacio- 
-es se ejecutan siguiendo un orden per- 
emente establecido: primero se opera 
_ e /ación a potencia, luego la multiplica- 



PROGRAMA 



10 
20 
30 
40 



REM 



50 

60 REM 
100 



100 



50 



30 



EJECUCION 



INFORMACION PARA 
EL PROGRAMADOR 



40 REM 



60 REM 



RESULTADO 
DE LA 
EJECUCION 



El comando REM permite al programador introducir comentarios dentro de los programas. 
Estos no serán ejecutados por el ordenador. 
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POTENCIACION 




* / 

MULTIPLICACION I DIVISION ) 





SUMA I RESTA 



PRIORIDAD DE LOS OPERADORES ARITMETICOS 



Al encontrarse con expresiones en las que se combinan datos por medio de operadores 
aritméticos, el ordenador ejecutará las operaciones de acuerdo a la prioridad establecida por el 
lenguaje BASIC Las operaciones encerradas entre paréntesis san las que gozan de 
máxima prioridad. 



eSs02© 





El ordenador dotado de un intérprete de lenguaje BASIC puede utilizarse a modo de 
calculadora. Para CÍlo hay que recurrir al empleo de instrucciones formuladas en modo 
directo. Por supuesto, en cada caso hay que respetar el modo de introducción adecuado. 



ción y/o división y, finalmente, la suma 
y/o resta. 

• Si es necesario alterar la prioridad de 
las operaciones, por ejemplo, ejecutar una 
suma antes de una multiplicación, pueden 
utilizarse paréntesis. Las operaciones en- 
cerradas dentro de paréntesis tienen prio- 
ridad máxima. 

• Si dentro de una misma expresión in- 
tervienen varias operaciones de igual prio- 
ridad, el intérprete BASIC las operará de 
izquierda a derecha. 

Los siguientes ejemplos, ilustran la aplica- 



ción práctica de las prioridades que im- 
pone el BASIC: 



5+3*2 = 11 
4+2/2=5 
4+2 t 2=8 
(5+3)*2=16 
(4+2)/2=3 



(4+2) 1 2=36 
6+4/2*7=20 
6+4/(2*7)=6,29 
9-5*8 t 4/2 =-10,231 
9-5*8 f (4/2) =-3 11 



A la hora de emular el funcionamiento de 
una calculadora, ejecutando instrucciones 
en modo directo, puede recurrí rse al em- 
pleo de variables. Por ejemplo, el si- 
guiente par de instrucciones visualiza el 
resultado de una suma operada por medio 
de una asignación: 



A=2+4 <RT) 
PRINT A (RT) 




En todo caso, es obvio que las posibilida- 
des de cálculo del BASIC no están conce- 
bidas para realizar simples operaciones en 
modo directo. Su verdadero destino es la 
entrada en los argumentos de instruccio- 
nes indirectas que darán cuerpo a progra- 
mas adecuados para resolver tareas más 
completas y evolucionadas. 
El programa que sigue constituye un 
ejemplo, sencillo aunque ilustrativo, de 
una aplicación de cálculo apoyada en la 
utilidad de los operadores aritméticos: 

10 INPUT "PRECIO DEL LITRO DE GASOLINA: 

20 INPUT "KILOMETROS A RECORRER: ";K 
30 INPUT "CONSUMO POR CADA 100 KMS: 

";G 

40 GA=P*K*G/100 

50 PRINT "EL GASTO EN GASOLINA ES 
DE: ";GA;' J PESETAS" 
60 END 

El cometido del programa consiste en cal- 
cular cuál va a ser el gasto en gasolina 
necesario para recorrer un determinado 
trayecto en automóvil Los datos que soli- 
citará el ordenador para realizar el cálculo 
son: precio del litro de gasolina, número 
de kilómetros a recorrer y consumo de 
gasolina porcada 100 Kms. (por supuesto, 
del automóvil que vaya a utilizarse en el 
viaje). Estos tres datos, deben introdu- 
cirse a medida que los solicite el ordena- 
dor, según vaya ejecutando las sucesivas 
instrucciones INPUT (líneas 10, 20 y 30), 

RUN 

PRECIO DEL LITRO DE GASOLINA: ? 80 
KILOMETROS A RECORRER: ? 250 
CONSUMO POR CADA 100 KMS: 7 10 
EL GASTO EN GASOLINA ES DE: 2000 
PESETAS 
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Logo (3) 

TURTLE GRAPHICS: 
dialogando con la tortuga 




La herramienta que brinda el 
LOGO para crear dibujos es la 
tortuga; un simpático colabo- 
rador dispuesto a ejecutar los 
desplazamientos que le ordene el usuario. 
En sus evoluciones a través de la pantalla, 
esta irá construyendo el dibujo al dejar una 
nuella visible de su trayectoria. En efecto, 
es como si ef inquieto personaje (levara 
una tiza adosada para perpetuar el rastro 
de sus movimientos. No cabe duda que la 
técnica resulta didáctica e incluso diver- 
tida, además de útil. 

mayor parte de las órdenes que en- 
tiende la tortuga son de tipo comando, SI 
bien, también existen operadores que re- 
flejan las condiciones en las que está 
actuando la tortuga (posición, color, etc.). 
Más adelante se analizarán incluso algu- 
nas posibilidades avanzadas que amplían 
a eficacia de esta técnica: operación pon 



varias tortugas simultáneamente, o trans- 
formación del aspecto de la tortuga a base 
de «disfrazarla». 

Antes de empezar con el trazec: ce jn 
dibujo, es ineludible observar el aspecto 
de la tortuga. Es importante distinguir la 
orientación de su cabeza. Este miembro 
es fundamental para el movimiento, 
puesto que indica la dirección en la que se 
desplazará el personaje. Una opción útil al 
respecto es pasar a la modalidad de pan- 
talla partida, introduciendo a través del te- 
clado la orden SS. La tortuga pasará a 
ocupar el centro de la pantalla. Situación 
en la que será inmediato comprobar cuál 
es su orientación. 

En el instante inicial, la tortuga debe en- 
contrarse mirando hacia el límite superior 
de la pantalla. Si su disposición fuera otra, 
será preciso llevarla al estado inicial te- 
cleando la orden CS. 

FORWARD 8 



APRENDIENDO A ANDAR 



Los desplazamientos más elemer:a es :e 
la tortuga son, naturalmente, los de avan- 
zar o retroceder a lo largo de la direcccr 
marcada por su eje longitudinal. Las : -te- 
nes que se ocuparán de instruirla al efecto 
son las siguientes: 
FORWARD: avance 
BACK: retroceso 

En ambos casos, ya sea el desplaza- 
miento hacia adelante o hacia atrás, hay 
que indicar al quelonio el número de ocs - 



BACK 4 



FORWARD A 



I — I — I — I— I 1 — \ — I — I — I— I — I — I — i — I — I — I 

6543210123456789 10 

- once y retroceso (FORWARD Y BACK); estos dos simples acciones son el pimío de partida de todo un vocabulario de órdenes que instruirán 
m la tortuga para la confección de dibujos en la pan tal ta. 
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Dos son los comandos 
destinados a ordenar el giro 
de la Tortuga: RIGHT (giro 
a derecha) y LEFT (giro a 
izquierda). En ambos casos, 
el comando correspondiente 
debe estar seguido por un 
número que exprese el 
ángulo de giro en grados. 



RIGHT 



LEFT 



ciones o «pasos» que debe dar antes de 
detenerse. Este número se introducirá 
tras el comando oportuno. 
Por ejemplo, con la orden FORWARD 50, 
la tortuga se desplaza 50 posiciones hacia 
adelante, dejando impreso el rastro de su 
trayectoria. Si queremos que retroceda 
hasta ocupar de nuevo su posición original 
bastará con ordenar un desplazamiento 
hacia atrás del mismo número de posicio- 
nes: BACK 50. Si se introduce de nuevo la 
instrucción BACK 50, la tortuga retroce- 
derá hacia el borde inferior de la pantalla 
visualizando su huella, Un nuevo FOR- 



WARD 50 devolverá a la tortuga al centro 
de la pantalla, con lo que se habrá dibu- 
jado una línea vertical de 100 posiciones o 
unidades de desplazamiento: 50 hacia 
arriba y otras cincuenta por debajo de la 
posición original que ocupaba la tortuga. 
Pasemos a movimientos más complejos. 
¿Es posible ordenar a la tortuga que cam- 
bie la dirección de desplazamiento? En 
efecto, basta sólo con instruirla para que 
realice el oportuno giro sobre sí misma. 
Los comandos al efecto son: 
RIGHT: derecha y 
LEFT: izquierda 
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© 



© 
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POSICION 
INICIAL 


RIGHT 
45 


FORWARD 

60 


BACK 
120 


FORWARD 
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LEFT 


BACK 


FORWARD 


BACK 


LEFT 


270 


60 


120 


60 


135 
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Ambos comandos deben acompañarse de 
un dato de entrada que señale los grados 
del giro (recuerde que un giro de 360 gra- 
dos equivale a una vuelta completa. 
La orden RÍGHT 90 dejará a la tortuga 
mirando hacia la derecha, mientras que un 
giro ordenado con LEFT 90, devolverá a la 
tortuga a la orientación de partida (apun- 
tando hacia la zona superior de fa pantalla). 
Supongamos que a partir de la posición de 
partida, ordenamos a la tortuga que eje- 
cute la orden RIGHT 90 y tras ésta, la 
orden FORWARD 50. El resultado será la 
aparición en la pantalla de una línea hori- 
zontal de 50 puntos hacia la derecha, a 
oartir del centro de la pantalla. Si quere- 
mos prolongar la línea horizontal por la 
izquierda, en otras cincuenta posiciones, 
será suficiente con introducir ahora la or- 
den BACK 100. 
¿Cómo devolver ahora a la tortuga a su 
posición de partida? Nada más fácil; aun- 
que es necesario comunicarle dos órde- 
nes: FORWARD 50 {regresa al punto cen- 
tral) y LEFT 90 (gira noventa grados para 
apuntar de nuevo al borde superior de la 
pantalla). 



Secuencia de órdenes que instruyen a la 
tortuga para que dibuje un aspa. 

RIGHT 45 
FORWARD 60 
BACK 12Ü 
FORWARD 60 
LEFT 270 
BACK 60 
FORWARD 120 
BACK 60 
LEFT 135 
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5?n lugar a dudas, el método es muy sim- 
óte. La figura adjunta muestra la serie de 
Adenes que educarán a ta tortuga para 
-je dibuje un aspa; un ejemplo que re- 
sume el empleo de los cuatro comandos 
: asentados, 



RETORNO AL ORIGEN 



Un nuevo ejemplo lo aporta el programa 
adjunto, cuya ejecución hará qae la tortuga 
dibuje un asterisco sobre la pama lía. 



^ara devolver a la tortuga en la posición 
" cial, se han utilizado hasta ahora los co- 
mandos de movimiento y giro Este es un 
método algo engorroso, puesto que las 
bayectorias de retorno dependen de la 
oosición que ocupe fa tortuga, distinta en 
rada caso. Un método bastante más có- 
modo para devolver af simpático quelonio 
2 la posición de origen es la que brinda el 
comando HOME. Su ejecución obliga a la 
tortuga a regresar al origen, volviendo a la 
orientación de partida Por supuesto, la 
nea que corresponde a la trayectoria de 
"eterno quedará impresa en la pantalla 
Si lo que se desea es volver al principio 
sorra ndo lo dibujado, hay que optar por 
otro comando CS (Clear Screen). Este eli- 
mina los rastros dejados por la tortuga y la 
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CS 


2 


FORWARD 50 


3 


BACK 100 


4 


HOME 


5 


RIGHT 90 


6 


FORWARD 50 


7 


BACK 100 


8 


HOME 
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LEFT 45 


10 


FORWARD 60 


11 


BACK 120 


12 


HOME 


13 


RIGHT 90 


14 


FORWARD 60 


15 


BACK 120 


16 


HOME 



coloca en su posición inicial. Uno de los 
gráficos adjuntos ilustra ef funcionamiento 
de los nuevos comandos, en esta ocasiór» 
dibujando un asterisco. 

PINTANDO CON LA TORTUGA 



Hasta ahora se han presentado algunos 
comandos que instruyen a la tortuga para 





Las órdenes HOME y CS devuelven a la tortuga ul origen o posición de partida. La diferencia 
entre ambas radica en que CS borra la pantalla por completo, mientras que 
HOME no altera los dibujos que pudieran existir en la misma. 



que realice dibujos conexos; o lo que es lo 
mismo, dibujos continuos en los que to- 
dos los trazos están unidos entre sí. Sin 
embargo, también es posible mover a la 
tortuga sin dibujar. Para fograrlo, existen 
algunos comandos que permiten contro- 
lar la "tiza" con la que la tortuga pinta 
sobre la pantalla. 

Para desplazar a Ja tortuga sin que ésta 
deje el rastro de su trayectoria, es necesa- 
rio "levantar" la tiza. El comando PENUP 
es el que ordena tal acción. Una vez ejecu- 
tado, los siguientes movimientos de la 
tortuga no imprimirán trazo alguno en la 
pantalla. 

Cuando haya que pintar de nuevo, habrá 
que ordenar a la tortuga que "baje la tiza". 
De ello se ocupa el comando PENDOWN. 
Este devuelve la tiza a su posición original, 
dispuesta para trazar [a huella del despla- 
zamiento sobre fa pantalla. El siguiente 
ejemplo muestra e! empleo de ambos co- 
mandos: 

CS 

PENUP 
FORWARD 50 
RIGHT 90 
PENDOWN 
FORWARD 50 
PENUP 
HOME 

El programa ejemplo dibuja una línea en la 
zona superior de la pantalla, devolviendo a 
la tortuga a su posición inicial. Las sucesi- 
vas acciones de la tortuga al ejecutar el 
programa, empiezan tras borrar la pantalla 
(CS) y "levantar" la tiza (PENUP). Acto 
seguido (FORWARD 50), la tortuga avan- 
zará 50 posiciones en sentido vertical sin 
imprimir huella. A continuación, girará 90° 
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TABLA DE ORDENES DEL 
"TURTLE GRAPHICS" (1) 


Instrucción 


Cometido 


Ope ra do r /co m a n d o 


FQRWARD <número> 
BACK <nümero> 
RIGHT <grados> 
LEFT <grados> 
HOME 
CS 


Avance de la tortuga 

Movimiento hacia atrás 

Giro a la derecha 

Giro a la izquierda 

Regreso al centro de pantalla 

Borrado de pantalla y retorno al origen 


Comando 
Comando 
Comando 
Comando 
Comando 
Comando 




TABLA DE ORDENES DEL 
"TURTLE GRAPHICS" (2} 


Instrucción 


Cometido 


0 per ador/coma ndo 


PENUP 


'Levanta" la tiza 


Comando 


PENDOWN 


rJ Baja" la tiza 


Comando 


PE 


Activación del borrador 


Comando 


PX 


Activación de tiza de color inverso (negativo 


Comando 


PEN 


Indica el estado de la tiza o modo de dibuje 


Operador 


CLEAN 


Borra la pantalla dejando a la tortuga en la 
posición que ocupa 


Comando 



a la derecha (RIGHT 901 para, de inme- 
diato, "bajar" la tiza (PENDOWN) y dibujar 
una línea horizontal de 50 posiciones al 
ejecutar la orden FORWARD 50. Para con- 
cluir su actividad, levantará de nuevo la 
tiza (PENUP) y regresará al origina! 
(HOME). 

Pero existen aún más posibilidades El co- 
mando PE (Pen Erase) activa el borrador 
que la tortuga lleva consigo. Por donde 
pase, después de ejecutar la orden PE H irá 
borrando lo dibujado. 



El último de los comandos de esta catego- 
ría es PX. Con este cebando a io r Ujga 
borrará lo que encuentre pintado y pintará 
allí donde no encuentre trazos. Hay que 
tener en cuenta que el efecto de PX es el 
de alterar el color de tiza de ta forma que 
siempre sea el opuesto al color de la zona 
sobre la que se desliza. En consecuencia, 
pintará trazos en "negativo", que al super- 
ponerse sobre fas líneas dibujadas con la 
tiza en su color normal las borrarán, 
He aquí un nuevo ejemplo: 



® yL (y 





px 

FORWARD 50 
RIGHT 90 
FORWARD 50 
HOME 

Al ejecutarlo, la tortuga recorrerá el 
mismo camino que en el ejemplo ante- 
rior; si bien, al estar activada ahora la fun- 
ción PX, trazará el "negativo" del dibujo 
previo y, en consecuencia, borrará la línea 
horizontal dibujada en el caso anterior. 
El siguiente ejemplo recurre a PE para 
borrar parte del dibujo creado en ef ejem- 
plo ilustrativo de PX: 

PE 

FORWARD 25 
RIGHT 90 
FORWARD 25 
HOME 

Concretamente, la zona borrada coincidirá 
con la primera mitad de la línea vertical 
dibujada en ei ejemplo anterior 

¿CUAL ES EL ESTADO 
DE LA TIZA? 



Combinando adecuadamente los comandos para el control de la «tiza»* es posible crear 
dibujos discontinuos sobre la pantalla y sacar un mayor partido a las posibilidades 
de la tortuga* 
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En cualquier momento, el programador 
puede perder la pista y no saber en qué 
modalidad está utilizando fa tiza. Para sol- 
ventar esta duda, se dispone de la función 
PEN. 

PEN es un operador cuya respuesta se- 
ñala el modo en el que está seleccionada 
la tiza. Los identificadores con los que res- 
ponde tal operador constan de dos letras 
cuyo significado es: 
PD; Modo PENDOWN 
PU: Modo PENUP 
PE: Modo Borrador 
PX: Modo Inverso o "negativo". 
Como quiera que PEN es un operador, 
habrá que utilizarlo precedido por un co- 
mando; por ejemplo: PRINT PEN, que es- 
cribirá en pantalla el tdentificador del 
modo en curso. 

Por último cabe mencionar la existencia 
del comando CLEAN. Su función es lim- 
piar la pantalla. Al igual que CS, borra to- 
dos los trazos anteriores. Pero a diferencia 
con aquél, no devuelve la tortuga a la posi- 
ción de origen. En definitiva, CS equivale a 
la asociación de los comandos CLEAN y 
HOME. 



s.o. 



El mundo del CP/M 

Génesis y características generales 

de la familia de sistemas operativos CP/M 



I acceso a los ordenadores por 
parte de personas con una for- 
mación informática media o 
básica, se ha hecho posible, 
en esta última década, gracias al desarro- 
□ de los modernos sistemas operativos. 
Su presencia en el ordenador permiten al 
jsuario desentenderse de la gestión y 
control de los dispositivos periféricos que 
habilitan la comunicación hombre/má- 
quina (pantalla, teclado, impresora ...), de 
íos dispositivos destinados al almacena- 
miento masivo de información (unidades 
de cinta, disco...), y de los recursos a asig- 
nar a las distintas tareas a procesar, así 
:omo de la gestión de las prioridades 
otorgadas a las tareas que aguardan su 
turno de ejecución. 

En consecuencia, el usuario puede sus- 
raerse de estas funciones, que aunque 
son de una importancia capital, pueden 



M0N0USUAR10 



MULTIUSUARIO 



MICROPROCESADOR 



8 BITS 



16 BITS 




8086 
8088 
68000 



CP/M-86 
CP/M-68K 

Goncurrert CRfH 





Dentro de la familia CV\M caben distintas versiones de este sistema operativo: para equipos 
basados en microprocesadores de 8 ó de 16 bits, y adecuadas para el trabajo en régimen 
monousuario o muttiusuario. 

llegar a constituir una labor más que te- 
diosa, sobre todo para el usuario que toma 
su primer contacto con el ordenador. 
Gracias a esta inestimable ayuda, el usua- 
rio puede colocarse en un nivel de abs- 
tracción tal, que le permita realizar una 
gestión transparente de la máquina. Con 
elfo, podrá dedicar su principal esfuerzo al 
desarrollo de aplicaciones, sin que sea ne- 
cesario un aprendizaje largo y exhaustivo 
de la máquina sobre la que va a trabajan 
El primer sistema operativo, de vocación 
generalizada, que vio la luz en el campo de 
los microordenadores fue el CP/TvI. Ac- 
tualmente, junto con sus diversas vahan- 
tes, es uno de los sistemas operativos 
más difundidos en el mundo de la mi- 
croinformática. 




o e o 



TAREA A RESOLVER. 



Una de las misiones encomendadas al 
sistema operativo es el control y la 
asignación de los recursos de la máquina a 
las tareas a resolver. 
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EL NACIMIENTO DEL CP/M 



A principios de los años 70, la informática 
se reducía aún a! entorno da las grandes 
máquinas. Ordenadores con una gran ca- 
pacidad de cálculo y considerable veloci- 
dad, aunque voluminosos y cuyo empleo 
sólo estaba al alcance de unos pocos ele- 
gidos. 

A partir de esta fecha empezó a cobrar 
auge la idea de sacar a la informática de su 
mundo cerrado y crítico, para acercarla al 
profesional que necesitara de su potencia 
de cálculo, pero que no tuviera a su al- 
cance un gran ordenador. 
En 1973, Gary Kildaíf, un empleado de la 
firma americana Intel, comenzó a diseñar 
un sistema operativo basado en los si- 
guientes criterios: 

• Destinado inicialmente a equipos basa- 
dos en microprocesadores de 8 bits, del 
tipo 8008 y 8080. 

• Con posibilidad de gestionar el almace- 
namiento de programas y archivos de da- 
tos en memorias auxiliares de bajo coste 
(en los denominados diskettes, floppy- 
disks o discos flexibles). 

• Que contemplara Ja creación de un en- 
torno lógico capaz de cubrir la parte física 
deJ ordenador (hardware) y que ofreciera 
al programador toda una colección de fun- 
ciones que facilitaran la completa comuni- 
cación entre el usuario y la máquina. Al 
mismo tiempo, debía permitir un acceso 
transparente a los qjy^sos cftsepsjtivos 
pedféricos. 

Unos años más tarde, en torno a 1976, 
Gari Kíldall creó Digital Researcn, la firma 
que r a partir de tal fecha, es la responsa- 
ble del desarrollo y comercialización del 
CP/M. ■ 

DESARROLLO DEL CP/M 



La gran aceptación de este sistema opera- 
tivo en el mercado de los microordenado- 
res, tiene su constatación en el hecho de 
que, en nuestros días, se ha convertido en 
un verdadero estándar. Con un número de 
usuarios que ha crecido vertiginosa- 




En régimen "monousuario' , sólo es posible la comunicación simultánea de un solo usuario 
con la máquina; el sistema Operativo asignará a éste todos los recursos del ordenador. 



mente, bajo el empuje derivado de su 
aceptación por un gran número de los 
principales fabricantes de microordenado- 
res, por ejemplo: Digital Equipment, He- 
wlett Packard, NCR r Texas Instruments, 
Altos, Bull r Olivetti, Sperry, Intel, ICL, To- 
shiba, ITT, Xerox, e incluso IBM. 
El desarrollo de programas para el sistema 
operativo CP/M no ha quedado a la zaga. 



tales, destinados a casi cualquier ámbito y 
sector de actividad. 

La evolución de este sistema operativo no 
sólo se ha manifestado en el aspecto 
cuantitativo con su rápida implantación en 
el mercado; la gestación y puesta en prác- 
tica de la nueva filosofía microinformática, 
incorporando los conceptos de multi usua- 
rio y multitarea, y el nacimiento de los 




La posibilidad de acceso simultáneo at ordenador por parte de varios usuarios se consigue en 
las configuraciones de tipo fí multiusuario'\ En este caso, el sistema operativo repane 
los recursos entre los diversos usuarios que comparten (a comunicación con la máquina. 



En la actualidad, es ingente la biblioteca 
de lenguajes, utilidades y software de 
aplicación destinada al CP/M. En ella se 
encuentran macro-ensambladores, intér- 
pretes y compiladores de BASIC, PAS- 
CAL, COBOL, FORTRAN, LISP y otros 
lenguajes de alto nivel; editores de líneas 
y de pantalla y un dilatado abanico de pa- 
quetes de aplicación, verticales y horizon- 



nuevos microprocesadores de 16 bits, ha 
tenido también un eco inmediato en el 
CP/M r determinando una importante va- 
riación cualitativa. 

Los conceptos de muít ¡tarea y multiusua- 
rio parten de la posibilidad de que un solo 
microprocesador (C P U.) atienda a varios 
usuarios y curse varias tareas. Ello se con- 
sigue mediante un mecanismo de asigna- 



PROCESO \ 




PROCESO H 



En modo li multiproceso*\ un único usuario puede beneficiarse de la ejecución de varios 
programas a la vez; ano de ellos ejecutado de forma interactiva y los restantes 
en modo "batch" O transparente al usuaria. 
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ción de intervalos de tiempo, en los que la 
^nidad central de proceso dedica su aten- 
: ón a un determinado usuario o tarea es- 
oecífica. Esta técnica denominada "Time 
e "cíng" r permite tiempos de utilización 
distribuida de !a CPU de unos 20 milise- 
:;undos como máximo por usuario o tarea 
en cada ciclo de atención. De esta forma, 
el usuario tiene la impresión de que los 
'ecursos de la máquina son exclusiva- 
mente suyos. 

El conjunto de estas innovaciones con- 
ceptuales, queda recogido en el sistema 
operativo MP/M {del inglés "Multi Pro- 
^ramming/Monitor"). Una variante, ba- 
sada en la misma estructura que el sis- 
Terna operativo CP/M, aunque incorpo- 
rando las nuevas herramientas que permi- 
ten explotar los conceptos de multipro- 
ceso y multi usuario 

E\ segundo punto a tener en cuenta es la 
^f'uencia que tuvo en el CP/M la apari- 



ción de los microprocesadores de 16 bits. 
La respuesta de Digital Research fue in- 
mediata y se plasmó en el desarrollo de 
los sistemas operativos CP/M-86 ¡mono- 
usuario y m anotares) y MP/M-86 fmulti- 
usuario y multita rea) destinados a los mi- 
croprocesadores 8086 y 8088 de Intel, 
Ambas versiones permiten al usuario dis- 
poner de un mayor volu^e~ ze ~e r ^c r: a 
central de acceso aleatorio (RAM) para el 
almacenamiento de los programas; libe- 
rándolo así de la restricción que supone el 
límite habitual de los 48 Kbytes de memo- 
ria RAM (cabe recordar que las 16 líneas 
del bus de direcciones de los microproce- 
sadores de 8 bits, sólo permiten el direc- 
cionam rento directo de 2 lfí =65.536 posi- 
ciones de memoria, y el sistema operativo 
suele ocupar alrededor de fos 16 Kbytes). 
La superación de esta barrera permite al 
usuario trabajar con programas más com- 
plejos, con los que acometer problemas 



que hasta el momento estaban vedados a 
los microordenadores. 



HARDWARE PARA CP/M 



El empleo del sistema operativo CP/M 
exige una configuración hardware mínima 
para que pueda realizar su cometido. Los 
elementos requeridos son: el microproce- 
sador, que ejecuta las instrucciones en 
código máquina; la memoria central utili- 
zada para almacenar la zona en curso de 
tratamiento o de ejecución del sistema 
operativo o de los programas; la memoria 
secundaria o de masa, para el almacena- 
miento de datos y programas externa- 
mente a la unidad central; la pantalla y el 



Evolución de los sistemas operativos 



El desarrollo de fos sistemas operativos 
ha sido paralelo a la evolución de los 
propios ordenadores, las máquinas a las 
que están destinados 

• En fos albores de la informática, surgió 
la PRIMERA GENERACION de sistemas 
operativos cuya característica básica era eJ 
trabajo secuencia!, desglosado en cuatro 
fases: perforación de las tarjetas con la 
información de entrada (tarea 
encomendada a una máquina denominada 
perforadora), lectura de los paquetes de 
tarjetas (lectora), ejecución del programa 
ipor parte de procesadores especializados) 
v salida de resultados (impresoras), 

• La SEGUNDA GENERACION se 
caracterizó por el tratamiento por lotes, 
^ambién era necesario que concluyera el 
'ote de trabajo en curso antes de pasar al 
siguiente. No obstante, el calculador 
descargó una gran parte de su actividad 
accesoria en máquinas especializadas, lo 





que permitía su completa dedicación a la 
parte central del proceso; ef cálculo. Una 
máquina especializada leía las tarjetas de 
datos y programas, y las grababa en una 
cinta magnética. Esta era procesada por el 
calculador central que vertía los resultados 
en una nueva cinta magnética, de cuya 
impresión se ocupaba una nueva máquina 
auxiliar. La veloc ; dad y eficacia 
se incrementó debido a la entrada en 
escena de las cintas magnéticas. 

• El siguiente eslabón de la cadena 
evolutiva llegó con la m uftiprogramación. 
Ahora, los ordenadores y los 
sistemas operativos de la TERCERA 
GENERACION., permiten que la memoria 
central del sistema esté ocupada por 
varios programas. Una vez ejecutado un 
programa, el propio ordenador 
pone a trabajar al periférico de salida 
adecuado, pasando él a ocuparse del 
tratamiento del siguiente programa. Una 
vez concluido este segundo :rabs;o, 





2% GtNERfiCJGN 
TRATAMIENTO 
POR LOTES 



3 a GENERACION 



í a GENERACION 
TELEMATICA 



o cuando ha terminado de realizarse la 
salida parcial de resultado deí primer 
programa, el ordenador regresa al 
tratamiento del primero o prosigue su 
actividad ocupándose del tercer programa 
almacenado en la memoria central. En 
esta tercera generación nacen 
Jas técnicas de m uitiprograma ción (la 
máquina almacena varios programas 
en la memoria central programas que 
parecen ejecutarse casi simultáneamente) 
y muttiusuario (el ordenador distribuye su 
atención entre varios usuarios que se 
comunican con la máquina a través de fos 
respectivos terminales; dada la 
vefocidad de tratamiento de información, 
parece que ef ordenador dedica una 
atención constante a cada usuario), 

• La CUARTA GENERACION puede 
definirse como la era de la informática 
distribuida y la telemática. Sintetiza 
Jas técnicas propias de la informática, las 
telecomunicaciones (el teléfono, el 
satélite...), métodos audiovisuales (TV r 
video-disco), nuevas técnicas de soportes 
documentales ( mi crofotog rafia, facsímil), 
rebotica... Los miniordenadores y 
microordenadores trasladan la informática 
a cualquier ámbito de actividad (industrial, 
profesional, educativo, doméstico. .) 
y nacen fas redes para la comunicación 
entre ordenadores que prestan, en su 
emplazamiento, una actividad de 
forma autónoma. 
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El CPlM es el primer sí sienta operativo de vocación gene rali zuda que surgió en el campo de la 
microinform ática . En ia actualidad caen í a con múltiples versiones adecuadas 
para muy diversos equipos. 



teclado, a través de los que el usuario 
dialogará con el ordenador, y los accesos 
o "ports" de entrada/salida, para la comu- 
nicación con los dispositivos periféricos 
asociados al equipo (impresora, tabla digi- 
talizadora, trazador gráfico...). 

Microprocesadores 

Los microprocesadores para los que se 
han desarrollado versiones de este sis- 
tema operativo son el 8080, 8085, 8086 y 
8088 de Intel y el Z80 de Zilog; todos ellos 

''Ó 

I I 



de 8 bits, excepto el 8086 y 8088 que son 
de 16 bits. El hecho de que el sistema 
operativo esté escrito en el lenguaje en- 
samblador propio de esta familia de mi- 
croprocesadores, motiva su absoluta de- 
pendencia de la máquina. Este punto su- 
pone un verdadero óbice que hace que el 
sistema operativo CP/M sea menos trans- 
portable a equipos de distinta naturaleza 
que otros sistemas operativos, por ejem- 
plo: UCSD y UNIX. Ambos son teórica- 
mente independientes de la máquina, ya 



que están escritos en un lenguaje de alto 
nivel: PASCAL para UCSD y "C" en el 
caso del UNIX. 

Memoria central 

El tamaño de la memoria central díreccio- 
nable depende del tipo de microprocesa- 
dor utilizado. En los microprocesadores de 
8 bits el espacio de memoria direcciona- 
ble llega hasta los 64 kbytes, y hasta más 
de 1 Megabyte en los microprocesadores 
de 16 bits. Ei empleo de estos últimos 
permite obtener configuraciones con una 
gran capacidad de memoria libre para el 
usuario, dado el continuo abaratamiento 
experimentado por los circuitos integra- 
dos de memoria RAM. 

Memoria secundaria 

Los dos tipos de memorias secundarias o 
de masa que coexisten, habitualmente, 
en los equipos con CP/M son las unidades 
de discos rígidos y las unidades de discos 
flexibles o "diskettes". 
El almacenamiento en diskettes está re- 
comendado para equipos que no exijan 
gran volumen de información almacenada 
y para los que los tiempos de acceso, en 
lectura y escritura, no constituyan un 
punto crítico. La cantidad de información 
memorizable en un disco flexible depende 
de condicionantes de grabación (densidad 
doble o densidad sencilla) y del número 
de caras del disco utilizadas al efecto f Sim- 
ple cara o doble cara). 
Por contra, las unidades de discos rígidos 
pueden llegar a almacenar de 5 a 40 Me- 
ga by tes en dispositivos de tecnología 
Winchester, con unos tiempos de acceso 
bastante inferiores a los obtenidos con 
discos flexibles. 

Pantalla y teclado 

El diálogo interactivo que permite el S.O. 
debe estar respaldado por un dispositivo 
periférico de tipo conversacional, a través 
del que el usuario sea capaz de comuni- 
carse La configuración típica consiste en 
un terminal con pantalla de tipo "CRT rr 
(Cathode Ray Tube) y un teclado seme- 
jante at de una máquina de escribir. 

Accesos de comunicación 

Con estas ventanas al exterior, el microor- 
denador es capaz de comunicarse con dis- 
positivos auxiliares, a través de accesos 
de entrada/salida en formato serie (habi- 
tualmente, según la norma RS/232), o pa- 
ralelo (interface para impresoras de tipo 
Centronics, BUS IEE-488 .) 




El acceso a la unidad central de proceso en ios sistemas que operan en régimen multutsuario ó 
muí litare a es gestionado por el sistema operativo. Este controla los intervalos de tiempo en los 
que cada proceso o usuario puede disponer de la atención de la CPU, de acuerdo a las 
prior id ades as ig nadas. 
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Software de gestión 

Las herramientas de gestión 
y productividad 



ara determinar la zona ocu- 
pada por las herramientas de 
gestión y productividad, den- 
tro del conjunto del software 
| aplicación, es preciso revisar ¡as distin- 
as clasificaciones que se imponen en 
ste campo. 

zn primera instancia, y atendiendo a su 
tilidad específica o generalizada en un 
determinado marco de tareas, cabe drstin- 
jir entre paquetes verticales y honzonta- 
Otra clasificación, en base a su proce- 
^ncia, diferencia entre software de crea- 
ción propia, adquirido como paquete es- 
ándar, o encargado para su confección "a 
cedida". 

D or último, y adoptando esta vez como 
criterio ef ámbito al que se destina ef pro- 
5 r ama o paquete de programas, se llega a 
= distinción entre software de juegos o 
entretenimiento, educación, gestión y 
croductivídad, científico/técnico y conta- 
bilidad/administración. 
E emplazamiento de las herramientas de 
gestión y productividad hay que preci- 
5arlo, en definitiva, dentro de los paquetes 
.: tercíales, estandarizados, y de tipo ho- 
^zontal. Los cinco grupos básicos integra- 
dos en esta categoría van a constituir el 
rojeto del presente capítulo. 

TRATAMIENTOS DE TEXTOS 



3 ventaja que supone el empleo de una 
: Guiadora, en lugar de i lápiz y ei papel a 
hora de realizar cálculos matemáticos, 
e semejante a la contrapartida del orde- 
sdor equipado con un tratamiento de 
xtos respecto a la tradicional máquina 
? escribir 

h paquete para eJ tratamiento de textos 



permite todas las funciones propias de 
una máquina de escribir, si bien, aporta 
todo un amplio surtido de posibilidades 
que facilitan, perfeccionan y aceleran ta 
confección de textos. Permite componer 
el texto en la pantalla, corregirlo con totaf 
comodidad, borrar o insertar nuevas pala- 
bras y párrafos en cualquier punto del 
texto editado, redistribuir los bloques de! 
texto y, por supuesto, imprimirto. En esta 
última función es, tal vez, donde se en- 
cuentra la mayor espectacular zz-z z- :.s 
procesadores de textos, puesic aue ser- 
rín i ten definir tanto el formato de presen- 
tación [texto por página, distribución de 
columnas y márgenes, espaciado entre lí- 
neas y párrafos), como, en muchos casos, 



El tratamiento de textos por medio de un 
ordenador sustituye c on ventaja a la 
t radie tonal máquina de escribir. Cualquier 
programa actual pura el proceso de textos 
brinda multitud de opciones que apoyan y 
automatizan la edición de texto escrito. 





La ventaja que supone el empleo de una calentadora en lugar del lápiz y el papel a 

¡a hora de realizar cálculos matemáticos, es semejante a la contrapartida del ordenador. 

equipado con un tratamiento de textos, respec to a la tradicional máquina de escribir. 
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determinado sistema operativo. Entre los 
más importantes se encuentran: 
WORDSTAR. EASYWRITER, VISIWORD, 
APPLE-WRITER, MAGIC WAND, EPIS- 
TOLE r WORD PERFECT, MICROSOFT 
WORD, WORDS, WORDMASTER, TEX- 
TOR... Muchos de ellos disponen de ver- 
siones adaptadas al castellano. Los más 
importantes serán objeto de un detallado 
estudio práctico dentro de la obra. 

HOJAS ELECTRONICAS 



Planificación financiera, evaluación de hipótesis económicas, confección de presupuestos, 
determinación de coates..., todas éstas son actividades que puede resolver el usuario, rápida y 
eficazmente, con la ayuda de un ordenador equipado con una ''hoja electrónica \ 



los tipos de letras en los que debe apare- 
cer cada zona del texto (carateres norma- 
les, en negrita, cursiva..! 
Todo este cúmulo de posibilidades, se 
completan con la no menos atractiva de 
almacenar los textos editados para su 
posterior utilización, modificación o inser- 
ción de zonas ya editadas en posteriores 
documentos. 



La utilidad de los paquetes de tratamiento 
de textos se manifiesta en cualquier situa- 
ción en la que sea preciso editar o tratar 
un texto, Ya sea para confeccionar cartas, 
preparar informes o crear documentos de 
cuidada presentación. 
Existen tratamientos de textos estandari- 
zados, creados para su incorporación a or- 
denadores personales equipados con un 



TRATAMIENTOS DE TEXTOS 


Nombre 


Sistemas operativos 


Origen 


APPLEWRtTER 
EASYWRITER 
MAC WRITE 
MAGIC WAND 
MAGIC WIN DOW 
TEXTOR 
VISIWORD 
WORD 
WORDSTAR 


Appte-DQS, PRODOS, SOS 
Apple-DOS, CP/M, MS/DOS 
Apple Macintosh 
OASIS 

Apple-DOS, ProDGS, SOS 
MS/DOS 

Apple-DOS, CP/M r MS/DOS 
MS/DOS 

CP/M, CP/M-86, MS/DOS 


Apple Computers 

Information Unlimi:ed Software 

Apple Computers 

Small Business Applications 

ARTSCI 

Talor 

VisiCorp 

Microsoft 

Micropro Internationa] 


HOJAS ELECTRONICAS 


Nombre 


Sistemas operativos 


Origen 


CALCSTAR 
MAGICALC 
M1CROPLAN 
MULTIPLAN 

PERFECT CALC 
PLANNER CALC 
SUPERCALC 
T/MAKER 11 
VISICALC 


CP/M, CP/M-86, MS/DOS 
Apple DOS, ProDOS 
CP/M, MS/DOS 
CP/M, MS/DOS, Apple-DOS 

V Otros 
CP/M, MS/DOS 
CP/M, MS/DOS 
CP/M, MS/DOS 
CP/M, MS/DOS 
MS/DOS, CP/M, Apple-DOS y 

otros 


Micropro International 
ARTSCI 
Chang Labs. 
Microsoft 

Perfect Software 
Target Software 
Sorcim 

T/MAKER Corp. 
Vi si Corp 



El concepto de hoja electrónica es una de 
las ¡deas más revolucionarias que han 
visto la luz en el terreno del software de 
aplicación. Hoy en día, su presencia en los 
ordenadores personales es sustantiva, 
hasta el punto de convertirse en una he- 
rramienta casi imprescindible para ejecuti- 
vos, economistas y, en general, para todo 
aquel profesional cuya actividad exige el 
uso constante de la calculadora y el papel. 
MULTIPLAN, VISICALC, SUPERCALC 
CALCSTAR, MAGICALC, T/MAKER ll r 
PERFECT CALC , son los nombres que 
identifican a algunas de las hojas electró- 
nicas más populares; nombres que se han 
integrado en el vocabulario cotidiano de 
muchos profesionales. 
La creación y análisis de modelos finan- 
cieros; la simulación de hipótesis acerca 
del funcionamieríto de una empresa; el 
cálculo del precio de un producto, en fun- 
ción de los costes de producción y comer- 
cialización; la evaluación de inventarios... 
Todas ellas son actividades que suelen 
resolverse a base de proyectar un gran 
volumen de cálculos sobre una tabla, pla- 
gada de casillas, dibujada sobre el papel. 
Cada vez que se altera el valor de una de 
las casillas de la tabla, es preciso recalcu- 
tar el contenido de las restantes casillas 
afectadas, esgrimiendo la calculadora. 
Un ordenador, dotado de un paquete de 
este tipo, es capaz de generar las tablas 
adecuadas sobre la pantalla. La intersec- 
ción de las filas y columnas de la tabla 
determina las casillas o células, cuyo con- 
tenido estará relacionado entre sí por fór- 
mulas o expresiones que definirá el propio 
usuario. El cálculo del conjunto de casillas 
será ahora una misión encomendada al 
ordenador, que realizará automáticamente 
a partir de los datos proporcionados por el 
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jsuario. Este puede simular cómoda- 
Tiente cualquier hipótesis, sin más que 
modificar el dato o datos que estime opor- 
tuno. El programa se ocupará del resto, 
^calculando la totalidad de la hoja electró- 
nica para reflejar la nueva situación. 

GESTION DE ARCHIVOS 
Y BASES DE DATOS 



El ejercicio de cualquier actividad, profe- 
sional o dentro def marco de una em- 
oresa, exige el tratamiento de un cierto 
volumen de información de muy diverso 
lipo: ficheros de personal, clientes o pro- 
veedores; archivo de documentos, co- 
'respondencía, informes de productos.,. 
La organización y tratamiento de todo 
este repertorio de datos, por medios in- 
formáticos, corre a cargo de los paquetes 
de esta categoría: los denominados 
DBMS (Data Base Management Systems 
o sistemas para la gestión de bases de 
datos). 

El software destinado a esa actividad, 
creado para ordenadores personales, 
constituye uno de los apartados de mayor 
asonancia y popularidad. Los paquetes 
estandarizados orientados a este come- 
: do (dBASE lf r dBASE 11 1, PFS File/Report, 
Omnis, DB Master, Visifííe, Fríday, Data- 
star...) ofrecen al usuario todo un conjunto 
de utilidades destinadas a facilitar la crea- 
ción de los archivos que integrarán la base 
de datos y su posterior tratamiento. 
~a mayor parte de los programas encua- 
drados en este apartado, permiten al 
usuario relacionar el contenido de los dis- 
tintos archivos, realizar operaciones mate- 
máticas con su contenido, clasificar los 
latos de forma automática y de acuerdo a 
tos criterios que se definan en cada caso, 
realizar búsquedas selectivas de informa- 
ción y, por supuesto, obtener informes 
ti presos del contenido de fos archivos, 
de acuerdo ai formato que establezca el 
propio usuario. 

PAQUETES GRAFICOS 



GESTION DE ARCHIVOS Y BASES DE DATOS 


Nombre 


Sistemas operativos 


Origen 


CX BASE 200 

DATASTAR 

DB MASTER 

dBASE IJ/íll 

FRIDAY 

INFOSTAR 

OMNIS 

PFS File/Report 
VISIFfLE 


Apple-DOS, ProDOS 
CP/M, MS/UOS 
Apple-DOS, ProDOS 
CP/M, CP/M-86, MS/DOS 
CP/M, MS/DOS 
CP/M. CP/M-86, MS/DOS 
MS/DOS, SOS, UCSD-pSystem 
Apple-DOS, ProDOS, MS/DOS 
Apple-DOS, CP/M, MS/DOS 


Controle X 

Micropro 

Stoneware 

AshtonTate 

Ashton-Tate 

Micropro 

Blyíh 

Software Publishing Corp. 
VisíCorp, 



GRAFICOS DE GESTION 


Nombre 


Sistemas operativos 


Origen 


BUSINESS 






GRAPHICS 


Apple-DOS, ProDOS 


Business and Professional 






Software 


CHARTMASTER 


Appíe-DQS, ProDOS 


Stoneware 


CP/M GRAPHICS 


CP/M 


Digital Research 


DATAPLOT 


Apple-DOS, ProDOS, SOS 


Muse Software 


dGRAPH 


CP/M, MS/DOS 


Fox & Geller 


MICROSOFT 






CHART 


CP/M, MS/DOS, Apple-DOS, 






APPLE Macintosh y otros 


Microsoft 


PFS GRAPH 


Apple-DOS. ProDOS, MS/DOS 


Software Publishing Corp. 


VISIPLOT 


Apple-DOS, CP/M, MS/DOS 


Vis i Corp 


VISITREND 


Apple-DOS, CP/M, MS/DOS 


Vis i Corp 



quetes de aplicación que goza de las pre- 
ferencias de los ejecutivos y profesionales 
en el área de gestión. El software gráfico 
da entrada a la imagen en las actividades 
de gestión, sustituyendo los tediosos in- 
formes económicos, repletos de cifras, 



por gráficos de muy diverso tipo: cu-%=s 
histog ramas, círculos de fraccionar e~ te 
proporcional... 

La utilidad de los gráficos de gestión co- 
mité el análisis visual de los datos y resul- 
tados, mostrando incluso las tendencias 




-jnto con las hojas electrónicas, el soft- 
ware gráfico constituye el grupo de pa- 



Entre las herramientas de gestión más ampliamente utilizadas cabe señalar a los paquetes 
para la gestión de archivos y bases de datos. Sa utilidad es sustantiva a la hora de 
automatizar el tratamiento del gran volumen de información que exige el ejercicio 
de cualquier actividad. 
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que pueden derivar de cada situación ana- 
lizada. Habitualmente, los paquetes de 
este tipo permiten al usuario elegir el 
modo de presentación gráfica entre un 
amplio abanico de alternativas. La actua- 



ción de un paquete gráfico suele estar 
asociada a una hoja electrónica. De esta 
forma, los resultados de la hoja son ofreci- 
dos al usuario a través de imágenes que 
proporcionan una visión casi instantánea 



del acontecimiento simulado o del análr 
acometido. 

La mayor parte de los programas gráfico- 
incorporan la posibilidad de volcar el grá- 
fico en una impresora o en un plotter (tra- 
zador gráfico), obteniendo, así, copias i 
presas para acompañar a los informes 
ilustrar la documentación relativa al tema 
Algunos paquetes para la generación de 
presentaciones gráficas son: PFS Graph 
VISIPLOT, VISITREND, dGRAPH, CHART 
MASTER, MICROSOFT CHART, DATA- 
PLOT, BUSINESS GRAPHICS... 



SOFTWARE DE 
COMUNICACIONES 



La evolución de los ordenadores persona- 
les avanza no sólo en el terreno del trata- 
miento autónomo de la información, sino 
también en el ámbito de su común ícacíór 
con el mundo exterior. 
En este apartado caben diversos tipos de 
programas y paquetes, destinados a facili- 
tar la comunicación con equipos periféri- 
cos, o a establecer el diálogo con otros 
ordenadores, ya sean del mismo modelo 
o de distinta categoría y potencia. 
De acuerdo a las necesidades de comunn 
cacica los principales grupos de paquetes 
de comunicaciones son los siguientes: 

— Convertidores de protocolo para co- 
municación con dispositivos periféricos, 

— Emuladores de terminales, que permi- 
tirán el diálogo de! ordenador personal con 
otros ordenadores de mayor potencia. 

— Paquetes para la creación de redes lo- 
cales (LAN: Loca] Area Networks), apoya- 
dos por el hardware adecuado. Dentro de 
un área geográfica limitada, permiten inte- 
grar dentro de una red de comunicación a 
un determinado número de ordenadores 
def mismo tipo o compatibles. Estos pue- 
den compartir la información puesta en 
juego por los diversos equipos asociados 
a la red. 

— Paquetes para comunicación remota, 
sin limitación geográfica; por ejemplo, vía 
modem, a través de línea telefónica. 
Otros paquetes que ya empiezan a entrar 
en el mercado son los que permiten al 
ordenador personal acceder a otras fuen- 
tes de datos: canales de comunicación 
específicos, públicos o privados, como, 
por ejemplo, el sistema "videotext". 




Dentro del software de comunicación caben desde programas adecuados para ta cómumeacim 
del ordenador con determinados dispositivos periféricos, hasta programas para la 
creación de redes locales de ordenadores, o paquetes para la comunicación remota, por 
ejemplo, a través de línea telefónica. 



80 



Basic 



Toma de decisiones 

Rupturas de secuencia incondicionales 
y condicionales 



u 



n programa es, en esencia, un 
| conjunto de instrucciones que 
detallan un trabajo a realizar 
por el ordenador. La perfecta 
conclusión del trabajo programado se ob- 
-jene al ejecutar ordenadamente las diver- 
sas instrucciones; esto es: en primer lu- 
gar, la máquina ejecutará la primera línea 
del programa, a continuación la segunda y 
así sucesivamente hasta terminar. 
Sabemos ya que el orden de las líneas de 
nstrucción dentro de un programa, viene 
:ado por el número de línea que las acom- 
paña. En consecuencia, una línea prece- 
derá a otra si su número de línea es infe- 

En algunos casos, es conveniente que el 
programa no se ejecute de forma total- 
mente secuencial. Hay ocasiones en las 
üue interesa que tras una cierta instruc- 
: ón no se ejecute la que está precedida 
ror el siguiente número de línea, sino otra 
ocalizada en otro punto del programa, 
^ara facilitar esta posibilidad, el BASIC 
ofrece medios adecuados para la ruptura 
Je secuencia. 



LA INSTRUCCION GOTO 



.a xiptura de la secuencia de ejecución de 
_^ programa puede ser r desde luego, obíi- 
:~:oria (incondicional); no obstante, tam- 
: en es posible que la ruptura no deba 
't =! izarse en cualquier caso, sino que de- 
:e n da del cumplimiento de una condición 
tí cuesta. Esta distinción está contem- 
plada en el lenguaje BASIC y de ahí que 
i- tan instrucciones distintas que permi- 
la programación tanto de rupturas in- 




condicionales como condicionales. GOTO 
es el comando BASIC que permite cons- 
truir tas instrucciones para la ruptura de 
secuencia o bifurcación incondicional. Su 
formato general es: 
GOTO < número de línea>. 
El número de línea que figura como argu- 
mento corresponderá a la instrucción que 



deseamos se ejecute a continuación; esto 
es: a la instrucción a la que debe reali- 
zarse el salto o bifurcación. Una vez ejecu- 
tada ésta, el programa seguirá ejecután- 
dose secuencialmente a partir del referido 
número de línea. 

Muchas versiones del lenguaje BASIC 
permiten incluir dentro del comando 






Ejecuta un salto al número de línea especificado, 

Formato: (Número de línea) GGTO{[<número de !ínea>] [<expresión>]} 

Ejemplos: GOTO 30 

20 GOTO A+30 



81 



PROGRAMA 



EJECUCION 










10 






20 






30 










70 






80 GOTO 170 






90 






100 






150 




160 




170 






180 




190 




200 




210 




220 




230 END 



La instrucción GOTO es la herramienta BASIC adecuada para ordenar rupturas de secuencia o 
bifurcaciones incondicionales. El programa de la figura se ejecutará normalmente hasta llegar 
a ta línea W. A partir de este punto se rompe ¡a secuencia por efecto de la instrucción 
GOTO 170; ésta provoca un salto a la línea 170 a partir de la que seguirá ejecutándose 
el programa. 



GOTO una expresión matemática; una 
vez calculada, su resultado identificará el 
número de línea al que hay que saltar. Por 
ejemplo, las dos instrucciones que siguen 
son equivalentes: 

GOTO 100 
GOTO 50*2 

Ambas instrucciones ordenan un satto a la 
línea 100 del programa. La utilidad de la 
instrucción GOTO se manifiesta especial- 
mente a la hora de programar tareas repe- 
titivas. Por ejemplo, el siguiente programa 
constituye un bucle sin fin que presentará 
en la pantalla el texto "CURSO DE BA- 
SIC" repetidamente. La ejecución sólo se 
detendrá cuando el usuario lo ordene por 
medios directos (accionando la tecla para 
el abandono del programa en curso, o 
desconectando el ordenador). 



10 REM DEMOSTRACION DE GOTO 
20 PRINT "CURSO DE RASIC" 
30 GOTO 20 




Otro ejemplo, algo más elaborado, recurre 
a una instrucción GOTO para realizar el 
cálculo de los cuadrados de los sucesivos 
números enteros (1, 2, 3...}. De nuevo, el 
programa constituye un bucle sin salida; 
el usuario debe interrumpir su ejecución 
por medios directos. 



10 REM CUADRADOS 
20 LET N=1 

30 PRINT 'EL CUADRADO DE"; N; 
N*N 

40 LETN-N+1 
50 GOTO 30 




ES: 



El programa resulta de lo más simple. La 
linea 20 da a la variable N el valor inicia" 
uno. Acto seguido está localizada la pri- 
mera instrucción del bucle repetitivo. Su 
cometido es mostrar el texto "EL CUA- 
DRADO DE", seguido por el valor del nú- 
mero (N) y el texto siguiente ("ES:"); ter- 
minando con el cálculo e impresión deí 
cuadrado def número en cuestión (N*N). 
La línea 40 se encarga de incrementar en 
una unidad el valor de N; de esta forma, ai 
regresar a la instrucción 30, por efecto del 
GOTO 30 localizado en la línea siguiente, 
se procederá al cálculo y presentación en 
pantalla del cuadrado del siguiente nú- 
mero. 



RUN 

EL CUADRADO DE 1 ES: 
EL CUADRADO DE 2 ES: 
EL CUADRADO DE 3 ES: 
EL CUADRADO DE 4 ES: 
EL CUADRADO DE 5 ES: 
EL CUADRADO DE 6 ES: 
EL CUADRADO DE 7 ES: 
EL CUADRADO DE 8 ES: 




TOMA DE DECISIONES 



Uno de los aspectos que diferencian más 
notoriamente a los ordenadores del resto 
de la extensa gama de máquinas electró- 
nicas de cálculo [registradoras, calculado- 
ras de bolsillo, etc. ] es, sin duda alguna, 
la posibilidad de tomar decisiones. A partir 
de datos suministrados, ya sea por el pro- 
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«Tarna en curso de ejecución, o bien por el 
jsuario que esté en ese preciso instante 
fente al teclado de la máquina, el ordena- 
dor es capaz de realizar una evaluación de 
acuerdo a lo consignado en el programa y 
lomar las decisiones para las que está 
■ g ruido, 

lugar a dudas, éste es un factor que 
coporciona a ¡a máquina una gran versati- 
zad, convírtiéndola en un instrumento 
M para resolver un ilimitado número de 
tereas. 

Como se recordó al principio del capítulo, 
r oro-grama en lenguaje BASIC consta de 
tna secuencia de líneas numeradas en 
"den ascendente. Estas líneas de ins- 
trucción se irán ejecutando, una tras otra, 
a ordenar la ejecución del programa. Du- 
nte la ejecución pueden presentarse si- 
daciones que exijan procesos distintos, 
_£ decisión del camino a seguir puede 
adoptarla el propio ordenador evaluando 
_~a determinada condición, si ésta se ve- 
r?fíca puede poner en práctica una deter- 
m nada acción y r en caso contrario, otra 
racción distinta. El ordenador debe, por 
[tentó, poseer un mecanismo que le per- 
- ta en tales situaciones tomar una deci- 
sión, de acuerdo con la condición o condi- 
ciones establecidas por el usuario. 
* _a oportunidad de la toma de decisiones 
es r pues, indudable. No obstante, hay que 
partir del hecho de que el ordenador por sí 
"i smo no tiene poder de decisión alguno; 
abe ser el propio programador quien es- 
aolezca los términos de 3a condición a 
eríficar así como la acción o acciones 
z je debe emprender la máquina como 
-apuesta. Por ejemplo, suponga que se 
rrata de dar al ordenador una serie de 
; neo números diferentes, para que los 
;jme y presente en la pantalla el resul- 
--.7.0. Una primera solución programadla 
podría ser !a siguiente; 



10 LET B=0 

20 PRINT "INTRODUZCA UN NUMERO" 
30 INPUT A 
40 LET B=B+A 
50 GOTO 20 



EJECUCION 



RUPTURA 
-DE SECUENCIA- 
EN BUCLE 




La posibilidad de romper ía secuencia de ejecución de un programa, permite al usuario 
programar bucles repetitivos. 

Lü presencia de la instrucción de salto hada atrás (GOTO 30}. crea un bucle iterativo que 
habrá que romper por medios ajenos al programa BASIC. 



BIFURCACION 
INCONDICIONAL 




BIFURCACION 
CONDICIONAL 




1 









-_ orograma pide la introducción de los 
ees i vos datos, calcula la suma y la pre- 



El lenguaje BASIC ofrece ai programador comandos adecuados para ordenar saltos o 
bifurcaciones incondicionales (GOTO) y condicionales ÍÍFITHEN); estos últimos se apoyan en 
el cumplimiento o no de una condición impuesta. 
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IF..THEN..ELSE 



1 



Ejecuta las instrucciones que siguen a THEN si se cumple la condición; en caso contrario, 
se ejecutan las instrucciones que siguen a ELSE, 

Formato: (Número de línea) IF <condición> THEN ^instrucción 1 >[ELSE<inslruecíóh 2>] 

Ejemplos: 20 IF A>0 THEN P=1 

40 IF A>0 THEN P=1 ELSE P=0 
50 IF X-5 THEN GOTO 120 



senta en la pantalla; sin embargo, no está 
capacitado para detectar cuándo se le han 
[fado ios cinco números. La ejecución cie- 
rra un bloque continuo, sin detención, ex- 
cepto por medios ajenos al propio pro- 
grama. 

Es preciso contar con un mecanismo que 
permita instruir a! ordenador para que sea 
capaz de tomar decisiones. De esta 
forma, será posible construir un programa 
que detecte la introducción de los cinco 



valores y, en ese instante, "decida" pre- 
sentar la suma de ellos y detener automá- 
ticamente el proceso en ejecución. 

ESTRUCTURAS DE CONTROL 




En la facultad de decisión, no sólo ínter- 
viene la habilidad del usuario para ingeniar 
condiciones a evaluar. Tan importante 
como lo anterior es el tipo de herramien- 
tas que brinde el lenguaje BASIC para tal 
cometido. Herramientas que el programa- 
dor debe utilizar en la forma apropiada, de 
acuerdo con las necesidades específicas 
en cada caso, para programar ias tomas 
de decisión. 



if/tlien/else 



GRAND PRIX 



D 




VUELTAS: 2 

RECORD VUELTA: 3 J 24" 

RECORRIDO TOTAL: 40 V. 



REPEAT 



VUELTAS 



UNTTL 



FIN DEL RECORRIDO 



Estructura de control REFEA TI UN TIL . «repetir ¡a acción indicada (dar uueftas ai circuito) 
hasta que se verifique la condición (fin de las cuarenta Lucilas que constituyen ct recorrido) 



Las herramientas de decisión que aporta 
el lenguaje BASIC se plasman en un con- 
junto de instrucciones que cabría denomi- 
nar estructuras de control. Las estructuras 
de control alteran el flujo o Ja secuencia de 
ejecución del programa, haciendo que en 
un determinado momento se ejecuten ur 
conjunto de instrucciones u otro, segur 
se verifique o no una determinada condi- 
ción. 

Existen diversos tipos de estructuras de 
control, si bien r la principal en el BASIC es 
la IF/THEN/ELSE. 

Su traducción a lenguaje convencional 
¡lustra claramente sus posibilidades: IF 
(Si) se cumple la condición, THEN (Enton- 
ces) ejecutar una determinada instruc- 
ción, ELSE (De lo contrario) ejecutar la 
instrucción siguiente del programa. 
Otra estructura de control, muy útil a la 
hora de tomar decisiones, es WHI LE/DO: 
WHILE (Mientras) se verifique la condi- 
ción, DO (Hacer) ejecutar la instrucción 
indicada. 

En este caso, la condición que debe verifV 
carse para que se ejecute la acción aso- 
ciada al DO, se evalúa antes de ejecutar 
por vez primera la instrucción o acción 
especificada Esto significa que si ai llegar 
a una estructura WHI LE/DO la condición 
es falsa, no se ejecutará ninguna vez fa 
instrucción que ocupa la zona DO. 
Hay otra estructura de control muy pare- 
cida a la anterior aunque con una ligera 
diferencia. Esta estructura es REPEAT/ 
UIMTJL: REPEAT (Repetir) la ejecución de 
la instrucción indicada UNTIL (Hasta que) 
se verifique la condición. 
El pequeño matiz que la diferencia de la 
estructura anterior es que, en este caso, 
primero se ejecuta la instrucción que si- 
gue a la zona REPEAT y, a continuación, 
se verifica si se cumple o no la condición 
impuesta. De verificarse, se ejecutará de 
nuevo la instrucción, y así sucesivamente. 
En consecuencia, siempre se ejecuta al 
menos una vez la instrucción asociada a la 
estructura de control. 
Por último, otra estructura de control bas- 
tante utilizada en multitud de programas 
es CAS E/O F. Su utilidad se manifiesta a la 
hora de evaluar una condición y como 
consecuencia, bifurcar a la instrucción 
asociada al estado de la condición. En de- 
finitiva, permite adoptar una decisión múl- 
tiple y ejecutar la acción o respuesta perti- 
nente en cada caso. Las instrucciones a 
ejecutar se colocan ordenadamente de- 
trás de la zona OF Al evaluar la expresión 
asociada a CASE, ha de obtenerse un re- 
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El microprocesador: un "cerebro' 
electrónico integrado 



La revolución informática es un hecho 
cuyo origen se encuentra en el 
vertiginoso avance de la electrónica. 

Aún está reciente en el tiempo la época 
en la que la tecnología electrónica se 
edificaba por completo sobre las 
voluminosas y frágiles válvulas de vacío. 
Pronto, llegaron los semiconductores, con 
el transistor al frente; su reducido 
volumen y consumo energético no tardó 
en relegar a las válvulas casi al olvido. 
El tercer peldaño lo aportó el desarrollo de 
la microelectrónica. Con ella se abría un 
nuevo horizonte de evolución, tan amplio 
como creciente ha sido el nivel de 
integración hacia el que avanzaron los 
ci rcu i tos e I ect ró n icos . 

Hacia finales de la década de los 60, se 



crearon los primeros circuitos integrados 
LSI (Large Sea le Integrationl, de alta 
escala de integración. Circuitos que 
alojaban cerca de 10.000 transistores o 
componentes electrónicos activos en una 
superficie inferior a un centímetro 
cuadrado. 

El avance no se detuvo y en el mes de 
noviembre de 1971 irrumpió en los 
canales comerciales un "chip" cuya 
referencia era INTEL 4004: el primer 
microprocesador. En la actualidad — con 
poco más de una década por medio — se 
producen chips que integra- más va- 
cien mil componentes activos y han visto 
fa luz un considerable número de 
microprocesadores de 8, 16 e incluso de 
32 bits. 



En sus orígenes, el microprocesador nació 
como alternativa a la multiplicidad de 
circuitos integrados lógicos, orientados a 
aplicaciones específicas, que debían 
fabricarse en series reducidas y de 
dudosa rentabilidad. 
Muy pronto, su versatilidad proyectó al 
microprocesador en el mundo informático. 
Este pasó a convertirse en !a unidad 
central de proceso de los 
microordenadores- Un "micro-cerebro" 
encargado de la manipulación y 
tratamiento de los datos, del control de 
las operaciones y de fa coordinación de la 
actividad del conjunto de dispositivos que 
dan cuerpo af ordenador. Todo ello, de 
acuerdo a las órdenes que derivan de la 
ejecución de una secuencia de 
instrucciones denominada programa. 
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TABLA DE CONVERSION 


ORDENADOR 


GC 


>TO 


IF/THEN/ELSE 


GOTO <nl> 


GOTO <expr.> 


IF/THEN 


IF/THEN/ELSE 


. e ÍTHENl . 

IF lGOTO( <nl> 

— - — í — . 


APPLE fl (APPLESOFT) 


GOTO <nl> 


— 


IF/THEN 


— 


IFTHEN <nl> 


APRJCOT (M-BASIC) 


GOTO <nl> 




IF/THEN 


IF/THEN/ELSE 


íthen\^ - 

IF UnTnf <nl> 


ATARf 


GOTO <n1> 


GOTO <expr.> 


IF/THEN 


— 


IF THEN <nl> 


CBM 64 


GOTO <nl> 


— 


IF/THEN 




IFTHEN <nl> 


DRAGON 


GOTO <nl> 




IF/THEN 


IF/THEN/ELSE 


i r p r i j ^. ítí & 


EQUIPOS MSX 


uu i u <m.> 




IF/THEN 


IF/THEN/ELSE 


lF {S E ™}< n '> 


HP-150 


GOTO <nl> 




IF/THEN 


IF/THEN/ELSE 


,F { T G H OT N oH> 


IBM PC 


GOTO <nl> 


— 


IF/THEN 


IF/THEN/ELSE 


IF GOTO <nl> 


MPF 


GOTO <nl> 




IF/THEN 




IF THFM ^nl-^ 
ir i r\L\\ < --.r\\^> 


NCR DM-V ÍMS-RA«Sm 


uUiU <,nl> 




IF THFM 
i vf \ n c i \ 


ir/ 1 MtFM/tLüt 


.JthenI . 

IF \G0T0p nl> 


NEW BRAIN 


GOTO <nl> 




IF/THEN 




1C ÍTHENÍ . 

">OTo} <nl> 


ORIC 


GOTO <nl> 


GOTO <expr> 


IF/THEN 


IF/THEN/ELSE 




SHARP MZ-700 (MZ-BASfC) 


GOTO <nl> 




IF/THEN 




1C Íthen) . 

IF \GÜT0f <,ll> 


SINCLAIR QL 


GOTO <nf> 


GOTO <expr> 


IF/THEN 


IF/THEN/ELSE 




SPECTRA VIDEO 


GOTO <nl> 




IF/THEN 


IF/THEN/ELSE 


1C Ithen\ „ .. 

IF \G0T0j: <nl> 


ZX-SPECTRUM 


GOTO <nl> 


GOTO <expr> 


IF/THEN 







FORMULACIONES DE LOS COMANDOS 

GOTO <nl>: Salto incondicional a la línea cuyo 
Bifurcación condicional, Ejecuta Ta instrucción o ir 

C ° n f TH£Ní" SE " ^ ¡nStrUCCÍÓn ° instrucciones r- - — - ™. « uc w vcm.^,^ , a ggi luición impuesta en ih 

lF { GOTO j <nl>: Oibilidad de omitir una de \m palabras Clave (THEN o GOTO) cuando la zona THEN contiene una instrucción de salte incondicional. 



GOTO <nl>: Salto rncondicronal a la línea cuyo número se indica. GOTO <expr.>: Salto incondicional a la linea cuyo número es el resultado de la expresión IF/THEN 
Bifurcación condicional. Ejecuta la instrucción o instrucciones asociadas a THEN si se cumple fe condición expresada e.n la zona IF IF/THEN/ELSE- Bifurcación condicional 
con zom ELSE. La instrucción o instrucciones asociadas a ELSE se ejecutarán en el caso de no verificarse la condición impuesta en IF 



sultado coincidente con un número en- 
tero (1,2,3,4,. .) Según sea tal valor, la 
instrucción OF ejecutada será la que 
ocupe ef primer fugar, ef segundo, ter- 
cero.,. Esta estructura de control se tra- 
tará posteriormente, en otro punto de la 
obra, dado que el lenguaje BASIC incor- 
pora una instrucción capaz de generarla 
directamente: ON/GOTO. 



Y A TOMAR DECISIONES 



Aunque hay dialectos del lenguaje BASIC 
que incorporan en su repertorio los co- 



mandos WHf LE/DO y REPEATAJNTIL, lo 
habitual es que omitan tales comandos y 
reduzcan su oferta a la instrucción IF/ 
THEN/ELSE. En cualquier caso, fas dos 
estructuras de control mencionadas pue- 
den simularse mediante el empleo ade- 
cuado de ¡a instrucción de salto condicio- 
na f IF/THEN/ELSE. Esta instrucción es 
una transposición práctica de la respectiva 
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Otra estructura de control muy frecuente es W HILE IDO: «mientras se verifique lu condición 
impuesta (pesa inferior) ejecutar la acción indicada (añadir peras a fu balanza)- 



estructura de control. Por lo demás, y 
ib /o muy pocas excepciones, esta ins- 
micción adopta idéntico formato en casi 
lodos los ordenadores personales presen- 
tes en el mercado. 

_e diferencia más generalizada se en- 
centra en los dialectos BASIC que omi- 
ten la zona ELSE. En todo caso, esta op- 
: ón queda implícita en la propia estruc- 
Tura IF/ÍHEN: si la condición que se ha de 
•erificar no es cierta, se ejecutará la linea 
fíente a la que ocupa la propia instruc- 
: n IF/THEN; de ahí que la función ELSE 
i-eda obviarse sin mayores problemas, 
incluso aunque esté disponible, el uso de 
a zona ELSE es opcional, de forma que en 
= práctica suele omitirse en muchos 
Sisos. 

endo al ejemplo anterior, ahora el or- 
denador sí puede estar ya en condiciones 
lera saber cuándo se le han dado los 
anco números; es posible programar la 
— a de decisión adecuada. Así pues, el 
«Senador podrá evaluar si se han introdu- 
cido ya los cinco números y r en conse- 
: .encía, calcular la suma, visualizar el re- 
citado y detener la ejecución del pro- 
grama. Veamos cuál será el nuevo as- 
jecto de! programa: 



10 LEÍ B-0 
20 LET N-0 

30 PRINT "INTRODUZCA UN NUMERO:' 
40 IIMFUT A 
50 LETN-N+1 
60 LET B=B+A 

70 IF N<>5 THEN GOTO 30 ELSE 
PRINT "LA SUMA ES-";B 
80 END 



E - esta ocasión, la variable N lleva la 
r,-r n ta de cuántos números se van intro- 
: ndo en el ordenador; su valor — ini- 
¡zado a cero — se incrementa en una 
M«dad cada vez que se teclea un nuevo 
A su vez, la variable B — también 
«balizada a cero — irá totalizando el valor 
3e la suma de los datos introducidos. 
3 Sínea 70 se comprueba la condición: 
- : r de N distinto de 5? Si la condición 
: e : ^mple r esto es, si aún no se han intro- 
ducido los cinco números a sumar, se eje- 
:_'¿'a la zona THEN y, en consecuencia, 
- - r esa ra de nuevo a la ejecución de la 
30 (GOTO 30). Por el contrario, si la 
gandición deja de cumplirse (N ha alcan- 
.se valor 5), se ejecutará la instruc- 



ción asociada a la zona ELSE; ésta pre- 
senta en la pantalla la suma total de los 
cinco datos. Acto seguido, el ordenador 
pasará a ocuparse de la instrucción 80 que 
pondrá fin a la ejecución del programa. 
El comando IF/THEN/E13E, está abierto a 
la construcción de muy diversos tipos de 
instrucciones de bifurcación condicional 
De acuerdo al estado de fa condición, 
puede desencadenar un salto o bifurca- 
ción a una determinada línea del pro- 
grama, o puede dar paso a la ejecución de 
una instrucción que no implique un salto 
(INPUT r PRINT, LET...). 
Para dotar de mayor versatilidad a esta 
instrucción, normalmente, es posible in- 
troducir detrás de la palabra THEN, o de la 
zona ELSE más de una instrucción, sepa- 
radas por el símbolo dos puntos (:). Con 
ello podrá ejecutarse más de una acción 



como respuesta a una misma decisión 
adoptada en la zona IF. Algunos intérpre- 
tes de BASIC permiten incluso suprimir la 
palabra THEN cuando ésta se completa 
con la instrucción GOTO. En tal caso, las 
dos instrucciones que siguen serán equi- 
valentes: 

70 IF N< >5 THEN GOTO 30 
70 IF N< >5 GOTO 30 

En otros dialectos BASIC, la palabra clave 
que se puede omitir en tal situación es 
GOTO. Por ejemplo: 

70 IF N< >5 THEN GOTO 30 
70 IF N< >5 GOTO 30 

De nuevo, ambas instrucciones serían 
equivalentes. 




La capacidad para i ornar decisiones es una de ias características más relevantes que otorgan 
a i a máquina los lenguajes de programación. Esta facultad pragramabie distancia aí ordenador 
de otras máquinas electrónicas de aplicación especializada* 
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IF/THEN 



I 10 LET N = 1 

H 20 IF N = 3 THEN 50 

B 30 LEI N = M + 1 

^0 GOTO 20 



Las insíri/í dones IF ¡THEN ¡ELSE (en su 
formulación completa u omitiendo la zona 
ELSE) permiten programar tomas de 
decisión asociadas a bifurcaciones o saltos 
en i a secuencia de ejecución del programa. 



ESTRUCTURAS DE CONTROL 
CON IF/THEN/ELSE 



Una vez descrito el funcionamiento de la 
instrucción IF/THEN/ELSE, es posible lie- 




La figura ilustra la ejecución del programa que aparece en la pantalla superior. 
Este incluye los dos tipos de bifurcaciones o saltos: condicional i linea. 20 i e incondicional 
(línea 40). Tai como se observa, el programa ejecuta ana acción reiterada (acumular sut estros 
elementos), hasta que se cumple la condivión establecida en la instrucción 20 tX=3i: en 
cuyo caso se produce un salto a la instrucción final. 










¿CUAL ES EL COLOR? 


ROJO 




INTENTELO DE NUEVO 






¿CUAL ES EL COLOR? 


VERDE 




i BRAVO . LO ACERTO ! 






■ 







varia al terreno práctico programando, por 
ejemplo, las resta ntes estr uctu ras de con- 
trol a partir de la propia IF/THEN/ELSE. El 
ejemplo que sigue simula totalmente el 



5 REM TOMA DE DECISION 
10 INPÜT "¿CUAL ES EL COLOR?"; C$ 
20 IF C$ = "VERDE" THEN GOTO 40 ELSE PRINT 

"INTENTELO DE NUEVO" 
30 GOTO 10 

40 PRINT '¡BRAVO, LO ACERTO!" 
50 END 



Puesta en práctica de una toma de decisión por medio de una instrucción del tipo 
IFf TH EN I ELSE. 

El programa formula ana pregunta al usuario ( Cual es el color'.'); fu corrección de la 
respuesta se comprueba en la línea 20. Si la respuesta es correcta, la ejecución 
proseguirá en la línea 40 \ presentando el mensaje oporttmo antes de dar por concluido el 
programa. Por el contrario, si la respuesta es errónea, la zona ELSE lo comunicará 
al usuario y la instrucción GOTO 10 de la linea 30 ordenara ana nueva ejecución 
del programa. 



comportamiento de la estructura de deci- 
sión WHILE/DO: 



10 INPÜT "INTRODUZCA EL NUMEROLA 
20 JF A-0 THEN GOTO 50 
30 PRINT A,2*A r A*A 
40 GOTO 10 
50 END 




La actividad del programa consiste, señen 
llámente, en presentar en la pantalla el 
número introducido, el doble de su valor y 
el cuadrado del número en cuestión. Esta 
tarea se lleva a cabo siempre que el nú- 
mero tecleado sea distinto de cero. Si e* 
número que se introduce es el cero, la 
condición será cierta y, en consecuencia, 
el programa concluirá por efecto de" 
GOTO 50 emplazado en la zona THEN. 
Cabe observar que si el primer número 
introducido es el cero, no se ejecutarán 
ninguna vez las líneas 30 y 40; como se 
recordará, ésta es una característica inhe- 
rente a la estructura de control 
WHILE/DO 
La estructura REPEAT/UNTIL se obtiene 
fácilmente por medio de una instrucción 
IF/THEN/ELSE. Una demostración elo- 
cuente la brinda el siguiente ejemplo, 
cuya funcionalidad es análoga a la de! pro- 
grama anterior: 



10 INPÜT "INTRODUZCA El NUMERO;" 

20 PRINT A«2*A.A*A 

30 IF A< >0 THEN GOTO 10 

40 END 



En este caso, aunque el primer número 
que se introduzca a través del teclado sea 
el cero, se mostrará en la pantalla el resul- 
tado de tas operaciones realizadas. Por lo 
tanto, siempre se ejecutará, al menos una 
vez, fa acción que corresponde a 3a zona 
REPEAT; característica ésta peculiar de ia 
estructura de control REPEAT/UNTIL. 
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Logo (4) 

Tratamiento de palabras y listas 



P h . o V 



r 



v w s N 



CARACTERES H 



•' AMARILLO 



PALABRAS 



> 



BLANCO 




_J AZUL 




VERDE 



— PALABRAS 




Una de las aptitudes más relevantes del LOGO es el tratamiento de palabras y lis fas. Las 
palabras son agrupaciones de va me teres (letras , números y ¡o símbolos especiales auioñzadosh 
mientras que fas Usías están constituidas por conjuntos de palabras o de otras listas más 
elementales ísu b! is tas ) . 



Una de las facetas más importan- 
tes del LOGO es el tratamiento 
de palabras y listas. En la termi- 
nología de este lenguaje, una 
salabra es un conjunto de letras, números 
: signos especiales. Dada esta defíni- 
: 6n r es obvio que cualquier palabra en 
castellano (o en otro idioma) coincidirá con 
una palabra LOGO. Cabe recordar que ya 
en capítulos precedentes se han utilizado 
palabras para dar nombre a las variables. 
- su vez, una lista no es más que un 
conjunto de palabras. Una frase, un pá- 
*2Ío, o incluso un texto, son ejemplos de 
istas, El lenguaje LOGO permite manipu- 
- con notable soltura ambos tipos de 
* elementos. En el tratamiento intervienen 
-.nos símbolos separadores que tienen 
55 gnada una específica función. 



SEPARADORES 



r separador es un símbolo especial cuya 
í ón es delimitar las distintas partes de 
Via 'frase" El principal separador en 
_ 1 30 es el espacio en blanco. Su presen- 
ta revela el fin de una palabra 

dos palabras se escriben una tras otra, 
5-n interponer un espacio blanco entre 
5~03S, el intérprete LOGO entenderá que 
trata de una sola palabra. Así pues, 
üNOYDOS es una palabra única, UNO 
*DOS será interpretado como dos pala- 
bras, y UNO Y DOS como tres palabras 
«ndepen dientes. 

. r ordenador preparado para dialogar en 
~ 20 no será capaz de asimilar, por 
templo, la orden SUM32. Si en su lugar, 
produce la orden SUM 32, la máquina 
" : ~ 5 rá como primera entrada 32 y será 
oaz de encontrar el segundo dato de 



entrada. La instrucción correcta será, en 
definitiva, SUM 3 2. Este es un ejemplo 
que ilustra la importancia que tiene la co- 
rrecta separación de las distintas zonas 
que intervienen en una instrucción. 



COMILLAS Y CORCHETES 



Una palabra puede ser un dato de entrada 
para una instrucción LOGO. En tal caso, la 
palabra ha de ir precedida por comillas. 
Para que el LOGO entienda que ÜNOY- 
DOS es un dato de entrada, esta palabra 



debe aparecer como: "UNOYDOS. Por 
ejemplo, para escribir en fa pantalla HOLA, 
la instrucción adecuada es: 
PR1NT J 'HOLA. 

Cuando hay que tratar dos o más palabras 
juntas, éstas deben agruparse en la forma 
adecuada, formando una lista: conjunto 
de palabras encerradas entre corchetes. 
[BUENOS DIAS] es una lista y el ordena- 
dor la tratará como si se tratara de una 
unidad. En cambio, "BUENOS "DIAS son 
dos palabras independientes: no constitu- 
yen una lista y r en consecuencia, el orde- 
nador las procesará por separado. Por 
ejemplo: 

PRINT [BUENOS DIAS] 

escribirá en la pantalla la lista completa. 



89 



Lenguajes 




El aperador COUNT contabiliza el número 
de ele memos que integran el dato 
tít entrada sometido a examen: éste pite tí e 
ser ¡/na palabra o una lista. En el primer 
caso se contarán tos caracteres que 
conforman la palabra, mientras que en el 
segando serán las palabras y sablistas 
los elementos contabilizados. 



Así por ejemplo: 

PRINT COUNT "HOLA (RT) 
4 

En efecto, el dato de salida o resultado es 
el número 4, puesto que son cuatro los 
elementos (caracteres) de la palabra exa- 
minada. Si en lugar de aplicar el operador 
COUNT a una palabra lo hacemos sobre 
una lista, los elementos a contar no serán 
ya caracteres, sino palabras y subastas: 



PRINT COUNT [BUENOS DIAS] (RT) 
2 

El resultado revela, en efecto, eJ número 
de palabras que intervienen en la lista se- 
ñalada. 




FIRST es an operador LOGO que tranca su dato de entrada (palabra o lista] tomando de éste 
el primer elemento. BUTFIRST realiza el mismó fraccionamiento, si bien, entrega como salida 
todos los elementos del dato de entrada exceptuado el primero. 

Tanto para [ ] (lista vacía) como para " 
(palabra vacía) el resultado de COUNT es 0. 



PRINT [BUENOS DIAS] (RT) 
BUENOS DIAS 



TRATAMIENTO DE PALABRAS 
Y LISTAS 



MAKE "LISTA 1 [MI NOMBRE ES] 

PRINT FIRST :LISTA1 

MI 

PRINT LAST :LISTA1 
ES 



El programa empieza haciendo uso del 
comando MAKE para definir la LISTA L 
Esta última palabra es el nombre que va a 
identificar a la variable, mientras que eí 
dato a asignar (la lista de palabras) coin- 
cide con MI NOMBRE ES. Acto seguido 
aparece la instrucción PRINT FERST 
:LISTA1, cuya finalidad es mostrar en la 
pantalla eí resultado de aplicar el operador 
FIRST al contenido de la variable LISTA! 
(cabe recordar la importancia de los dos 
puntos como indicador de variable). Por 
supuesto, el dato de salida es MI: la pri- 
mera palabra o elemento de la lista, 
La siguiente instrucción ordena la presen- 
tación en pantalla del último elemento de 
Ja referida lista, para lo cual se utiliza el 
operador LAST, 

Los otros dos operadores presentados 
aplicados a la misma lista definida, darán 
como resultado el que muestra la si- 
guiente pantalla: 

PRINT BUTFIRST 1ISTA1 
NOMBRE ES 



Una lista puede incluir, a su vez, otras 
listas de menor entidad o sablistas. Por 
ejemplo: 

[HOLA [BUENOS DIAS]] 
es una lista de dos elementos: una pala- 
bra y una sublista. La sublista en cuestión 
consta de dos elementos que en este 
caso coinciden con dos palabras simples. 
El concepto de elemento queda total- 
mente clarificado con el uso del operador 
COUNT (contar). 

COUNT admite como dato de entrada una 
palabra o una lista, y devuelve como dato 
de salida el número de elementos que 
constituyen fa entrada. 



El LOGO posee un nutrido grupo de ope- 
radores especializados en ei tratamiento 
de palabras y listas. En primer lugar cabe 
mencionar los cuatro siguientes: FIRST 
LAST, BUTFIRST y BUTLAST, Todos ellos 
son aplicables tanto a palabras como a 
listas, 

FIRST y LAST devuelven, respectiva- 
mente, el primer y el último elemento del 
dato de entrada, mientras que los otros 
dos operadores hacen exactamente lo 
contrario; esto es: BUTFIRST elimina el 
primer elemento y BUTLAST el último. 
Veamos el siguiente ejemplo: 



PRINT BUTLAST : LISTA 1 
MI NOMBRE 

BUTFIRST presenta el contenido de la 
lista especificada, una vez suprimido el 
primer elemento, mientras que BUTLAST 
muestra la lista en cuestión exceptuando 
el último de sus elementos. 
Las posibilidades de los cuatro operado- 
res descritos no se reducen a Ja simple 
actuación independiente. Pueden aso- 
ciarse para dar un tratamiento más com- 
plejo a los datos de entrada. 

PRINT FIRST FIRST BUTLAST :LISTA1 
M 

Este es un ejemplo algo más complicado 
que combina la presencia de dos operado- 
res FIRST y uno de tipo BUTLAST. Cabe 
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corda r que su aplicación es extensiva a 
tas y a palabras, actuando sobre los ele- 
entos correspondientes: palabras en el 
so de que se traten listas y caracteres 
n el caso de tratar palabras, 
i instrucción del ejemplo aplica el opera- 
or BUTU\ST al dato de entrada consti- 
ido por fa lista definida (MI NOMBRE 
S); el dato de salida será, en consecuen- 
a ( la lista MI NOMBRE. A su vez, esta 
ta actúa como dato de entrada de un 
erador FIRST, con lo que el nuevo dato 
e salida será la palabra MI. Por último, 
ta constituye el dato de entrada del pri- 
er operador FIRST. Ahora, ya no es una 
a el dato afectado por FIRST sino una 
labra, de ahí que el resultado coincida 
n el primer elemento o carácter de la 
isma: M. 

s nuevos operadores LOGO destina- 
os al tratamiento de listas [en esta oca- 
ón no son adecuados para operar con 
-labras), son FPUTy LPUT. Su cometido, 
strado por el siguiente ejemplo, es aña- 
t un elemento al principio o al final de la 
lía indicada. 

RINT FPUT "JUAN :LISTA1 
UAN MI NOMBRE ES 

"INT LPU1 [JuAN PEREZ] :LISTA1 
I NOMBRE ES JUAN PEREZ 

n el primer caso se inserta la palabra 
AN delante de la L1STA1, por medio del 
-rador FPUT, La segunda instrucción, 
e ¡lustra la actuación de LPUT, añade la 
ta JUAN PEREZ al final de la indicada 
_r medio de la variable LIST1. 
como FPUT y LPUT sólo admiten lis- 
como segunda entrada, el operador 
RD admite únicamente palabras. Su 
ion es transformar a un conjunto de 



TABLA DE ORDENES -LOGO 


Instrucción 


Cometido 


0 p e rado r/Coma n d o 


COUNT <objeto> 


Cuenta elementos 


Operador 


FIRST <objeto> 


Da el primer elemento 


Operador 


LAST <ob¡eto> 


Da el último elemento 


Operador 


BUTFIRST <objeto> 


Elimina primer elemento 


Operador 


BUTLAST <objeto> 


Elimina último elemento 


Operador 


LPUT 


Añade al final 


Operador 


FPUT 


Añade al principio 


Operador 


LIST 


Construye una lista 


Operador 


SE 


Construye una lista de palabras 


Operador 


WORD 


Construye palabras 


Operador 


ASCII <palabra> 


Da el código ASCII de la inicial 


Operador 


CHAR <número> 


Da el caracter ASCII correspon- 
diente 


Operador 



< objeto >: puede ser una palabra, una ítsta, ur* número 

palabras en una palabra única, Así, por 
ejemplo, la salida de WORD "POR "QUE 
es la palabra PORQUE. 
Sí el número de entradas es superior a 
dos f es necesario encerrar entre parénte- 
sis al operador WORD y a los datos de 
entrada que lo acompañan; 
(WORD "TA JJ TE J TI "TO J TU) 
Cuando el objetivo sea construir una lista, 
hay que optar por el empleo de LIST. Este 
operador construye una lista integrada por 
sus datos de entrada. 
Al contrario de WORD, LIST sólo admite 
dos entradas; éstas pueden ser tanto pa- 
labras como listas. 



o una variable {ver tabla de entradas y salidas) 



MAKE "YO [JUAN PEREZ] 
PRINT WORD "JUAN "PEREZ 
JUAN PEREZ 

PRINT LIST rLISTAI :Y0 

[MI NOMBRE ES] [JUAN PEREZ] 




FPUT v 
LPUT son 
operadores 
cuya 

especialidad 
es añadir 
palabras o 
s id? lis tas al 
principio o al 
final. 

respectiva- 
mente, de la 
lista que 
figura como 
segundo dato 
de entrada. 



El ejemplo añade a la definición realizada 
anteriormente (LISTAD, la definición de 
una nueva variable de tipo lista con la que 
operar (YO). La segunda instrucción 
PRINT incluye al operador LIST, cuyo 
efecto es construir una nueva lista a partir 
de las dos sublistas especificadas corno 
dato de entrada. 

Otro de los operadores de esta categoría 
es SE (SEntence). Admite cualquier nú- 
mero de entradas, expresándolas al igual 
que en el caso de WORD. 
SE sintetiza una lista resultante a partir de 
sus entradas, si éstas son palabras, o a 
partir de los elementos de los datos de 
entrada si éstos son listas. En definitiva, la 
lista de salida de SE constará de palabras 
y nunca de sublistas como era el caso de 
LIST 
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NATURALEZA DE LOS DATOS DE 


ENTRADA Y SALIDA 


Operador 


Entrada 1 


Entrada2 


Salida 




<pal/lis> 




< numere» 


— S~*_AST 


<paíabra> 




<caracter> 




<lista> 




<pafabra/sub1¡sta> 


5^~RST/BUTLAST 


<palabra> 




<palabra> 




<lista> 




<Hsta> 


LPUT/FPUT 


<pal/IEs> 


<lista> 


<lista> 


WORD 


<palabra> 


■apalabra > 


<palabra> 


LIST 


<pal/1is> 


<pal/lis> 


<lísta> 


SE 


<pal/lís> 


<pal/1is> 


<lista> 


ASCII 


<ca ráete r> 




<número> 


CHAR 


<número> 




<caracter> 




La diferencia 
entre LIST y 
SE radica en 
que LIST 
asocia 
sublistas. 
míe ni ras qtic 
SE construye 

listas finales 
agrupando las 
palabras de los 
datos de 
entrada. 



Una prueba palpable de tal distinción en- 
tre SE y LIST la aporta la inclusión del 
operador COUNT en las dos últimas ins- 
trucciones PRINT del siguiente ejemplo: 

PRINT SE :LISTA1 :Y0 

MI NOMBRE ES JUAN PEREZ 

PRINT COUNT LIST : LISTA! :Y0 
2 

PRINT COUNT SE :LISTA1 :Y0 



5 
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El primer COUNT aplicado a LIST cuenta 
las sublistas {2} r mientras que el segundo 
cuenta las palabras resultantes (51. 

Los párrafos precedentes resaltan la im- 
portancia que tiene distinguir perfecta- 
mente en las entradas y salidas cuándo se 
trata de palabras y cuándo de listas. 

Si un operador recibe una entrada de tipo 
erróneo, el ordenador mostrará en la pan- 
talla un mensaje de error. Por ejemplo, 
después de teclear: FPUT "IN "CREIBLE. 
Aparecerá el mensaje: FPUT DOESN T 
LIKE "CREIBLE AS INPUT (FPUT no ad- 
mite "CREIBLE como entrada). Un ligero 
repaso al operador FPUT le hará reparar 



en que la segunda entrada no puede ser 
una palabra sino que debe ser una íista 



EL OPERADOR ASCII 



El ordenador almacena y trata la informa- 
ción codificada a modo de palabras bina- 
rias o grupos de ceros y unos. Tanto las 
instrucciones como los datos (numéricos 
o alfanumén'cos) adoptan este aspecto 
para que puedan ser manipulados por la 
máquina. 

A fa hora de proceder a la codificación, el 
ordenador puede acogerse a uno de los 
muchos códigos alfanuméricos, estanda- 
rizados o no, capaces de adecuar la infor- 
mación para que sea mantpulable por los 
circuitos electrónicos Entre ellos, el más 
estendido es el código ASCII (American 
Standard Code for Information Inter- 
cha nge). A pesar de su naturaleza de có- 
digo estándar, existen distintas versiones 
de! código ASCII, cuyas diferencias radi- 
can en la inclusión de un mayor o menor 
número de caracteres especiales; no obs- 
tante, las letras tienen siempre asignados 
los mismos códigos: del 65 (A) al 90 (Z). 
El LOGO dispone de operadores que per- 
miten la conversión de carácter o código y 
viceversa. El primero de ellos, ASCII, de- 
vuelve el código del carácter que se espe- 
cifique como dato de entrada. 

La función opuesta corre a cargo del ope- 
rador CHAR. Este transforma un número 
de entrada en el carácter ASCII correspon- 
diente. 



PRINT ASCII "A 
65 

PRINT CHAR 66 
B 

PRINT CHAR SUM 1 ASSCII "B 
C 



Los ejemplos anteriores ilustran la actua- 
ción de ambos operadores. 



s.o. 



Estructura del CP/M 

a arquitectura interna 
del sistema operativo 




I conectar el ordenador, la pan- 
talla se ve ocupada por un 
mensaje descriptivo de la ver- 
sión CP/M utilizada. Este sim- 
óle hecho conlleva toda una frenética acti- 
vidad en el interior de la máquina. Una 
sucesión de rápidas operaciones que pa- 
san completamente desapercibidas para 
el usuario, a no ser por los siseos y crují- 
aos que proceden de la unidad de disco, 
-^veladores de que algo está sucediendo 
en la ¡ntim dad de ; ordenador. 

¿QUE OCURRE EN LA INTIMIDAD 
DE LA MAQUINA? 



_3 descripción cronológica de los hechos 
t: en breve síntesis la que se describe a 
rontinuacióm Un programa "cargador" de 
arranque en frío (cold start), viaja desde el 
disco hacía la memoria residente del sis- 
:ema. La función de este programa no es 
jfcra que gestionar la carga del sistema 
jrjerativo desde el disco rígido o disquete 
a la memoria interna, cediendo el control, 
i continuación, al propio sistema opera- 
tivo CP/M. Este se encargará de ultimar 
as operaciones de inicia lización y de vi- 
sualizar en la pantalla el mensaje de pre- 
sentación, acompañado del carácter de 
petición o "prompt" de sistema, 
^oda la actividad da comienzo con la carga 
en memoria de un programa (cold start) 
. a única misión es gestionar la carga de 
□tro programa: el sistema operativo. 

C ^¿1 es la razón de esta aparente duplici- 
dad? La respuesta se encuentra en la ne- 

t i- ciad de garantizar la independencia en- 
ye el sistema operativo y la máquina, y 
e*te> es, precisamente, fo que se consigue 
con la intervención previa del programa 



cargador. De esta forma, es posible que 
microordenadores completamente dife- 
rentes puedan utilizar las mismas unida- 
des de discos y la misma copia del sis- 
tema operativo CP/M, 



ORGANIZACION INTERNA 



La gestión de las diversas funciones del 
sistema operativo no corren a cargo de un 
único programa completo; en realidad, se 
utilizan pequeños móduíos menos com- 
plejos y orientados específicamente ;- re- 
solver una determinada tarea E" - de" : ¡n¡ 
tíva, el sistema operativo está construido 
a base de un conjunto de módulos espe- 
cializados. Semejante estructura modular 
mejora su rendimiento, a la vez que se 
proporciona una gran flexibilidad ante po- 
sibles cambios y modificaciones. 




Los distintos módulos que integran el sis- 
tema operativo CP/Tvl son los que se indi- 
can a continuación: 

• CCP: Procesador de comandos de con- 
sola o Consolé Command Processor. 

• BDOS: Sistema operativo básico de 
disco o Basic Disk Operating System. 

• BIOS; Sistema básico de entrada/sa- 
lida o Basic fnput/Output System. 

La función del primero de ellos (CCP) es 
facilitar una comunicación directa con la 
máquina por medio de ciertas frases con- 
venidas, que sirven para ejecutar órdenes 
o comandos. El segundo módulo (BDOS) 
está especializado en la gestión de la me- 
moria secundaria, o dispositivos para el 
almacenamiento masivo y permanente de 
información; desde un nivel lógico, sin en- 
trar en la parte física de estos dispositivos. 
Por último, el módulo (BIOS) es el respon- 
sable de la ejecución de las funciones de- 
pendientes del soporte físico o hardware 
del sistema. 

La unión conjugada del CCP con el BDOS, 



MENSAJE DE 
PRESENTACION 

CURSOR 

PETICION 0 PROMPT 
DEL SISTEMA 



Pantalla de presentación del CP}M, Una vez conectado el equipo y cargado el sistentá 
operativo, !a pantalla se ve ocupada por un mensaje de presentación. Bajo éste, 
aparece el indicador de petición o «prompt» del sistema, acompañado por eí cursor que 
el punto de escritura. 



? na i a 
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constituye !a zona lógica del sistema, in- 
dependiente del entorno y, por lo tanto, 
transportable a cualquier otro sistema, 
aun cuando éste no comparta la misma 
configuración de dispositivos periféricos. 
Por contra, eí módulo BIOS contiene los 
programas que establecen fa comunica- 
ción directa con los dispositivos físicos. 
Con frecuencia, el BIOS es escrito por e! 
propio fabricante del ordenador y, debido 
a ello, no es trasladable a otro entorno 
físico (hardware) distinto al que ha condi- 
cionado su diseño, 

CONVENIOS ADOPTADOS 



Para una visión más clara de la notación 
utilizada, tanto en el texto como en las 
figuras, se convendrán los siguientes pun- 
tos; 

— En las referencias a comandos, la zona 
tecleada por el usuario aparecerá en letra 
cursiva. 

— Los caracteres especiales., obtenidos 
al accionar simultáneamente la tecla 
CONTROL {representada por CTRL r CTL o 
ATL en algunos microordenadores) y otro 
carácter, se representarán por medio del 
símbolo CTRL seguido por un guión y el 
carácter correspondiente, todo ello ence- 
rrado entre corchetes angulares. Por 
ejemplo, el carácter de control resultante 
de pulsar la tecla CONTROL y la letra U, 
se representará en la forma: <CTRL*U>. 

— Al hablar de disco en general, no se 
harán distinciones entre el disco rígido y el 
flexible o disquete. 

— El retorno de carro <CR> necesario 
para la ejecución de los comandos, no se 




El CPfM suele residir en un disco, ya sen de 
tipo flexible o rígido. En ei primer caso, ei 
usuario debe introducir ei disco en ta 
correspondiente unidad para que ei 
ordenador pueda acceder a la inteligencia 
básica que aporta el sistema operativo. 



indicará a no ser que se considere ineludi- 
ble su presencia para una mejor compren- 
sión. 

LA COMUNICACION 
HOMBRE-MAQUINA 



El diálogo entre el usuario y el microorde- 
nador, se lleva a efecto a través de un 



repertorio de órdenes o comandos, cuy- 
número es limitado y que deben ajustarse 
a unas reglas de vocabulario y sintaxis. 
El módulo CCP es, esencialmente., un in- 
térprete de comandos: acepta las órde- 
nes introducidas por ei usuario a través 
del teclado y las analiza sintácticamente 
para verificar su corrección antes de eje- 
cutarías. Tal ejecución puede involucrara 
los otros dos módulos, BDOS y BIOS, er 
el caso de que la puesta en práctica del 
comando en cuestión exigiera Ja interven- 
ción de alguno de ellos. 
La disponibilidad del sistema para aceptar 
un comando viene determinada por la 
aparición en la pantalla del indicador de 
presencia o de petición de entrada: el 
prompt del sistema. Este consta de una 
letra indicativa del disco accesible en el 
preciso instante y del carácter "mayor 
que" (>), Habitualmente, aparece como 
"A>". 

A! introducir cualquier comando, el CCP lo 
analiza y comprueba que es correcto. 
Aunque su expresión sea correcta, si 
forma parte de una lista de comandos que 
residen permanentemente en la memoria 
del microordenador, se buscará en el di- 
rectorio del disco un fichero de tipo 
"COM" cuyo nombre comparta los ocho 
primeros caracteres (o hasta el primer es- 
pacio en la línea del comando). Una vez 
localizado, el fichero se carga en la memo- 
ha y, a continuación, se ejecuta. Este tipo 
de comandos son los denominados co- 
mandos transitorios. 

Puede ocurrir que un programa de usuario 
sea excesivamente voluminoso e invada 
la zona reservada al CCP; en tal caso, se 
perderá la comunicación con el sistema, y 
el usuario perderá fa facultad de dar órde- 
nes inteligibles para el microordenador. 
Para romper con esta situación, puede re- 
cu rrirse a la combinación de dos teclas 
<CTRL-C>, que accionadas simultánea- 




Tras conectar eí ordenador, se desarrollan toda una serie de operaciones que concluyen con la puesta en pantalla del mensaje de presentación y, 
en definitiva, con el trasvase al interior de la máquina de su inteligencia elemental: et sistema operativa. Después de dar tensión al 
ordenador e introducir el disco del sistema operativo en el periférico correspondiente, la máquina lee del disco un programa ' cargador en frío", 
cuya ejecución gestionará fa carga del sistema operativo. 
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ARCHIVOS 




El CP¡M es un sistema operativo dotado de una estructura modular que mejora m rendimiento y le otorga fle xibilidad frente a posteriores 
cambios o actualizaciones. Cada uno de los módulos gestiono 101 determinado grupo de tareas propias del ordenador. 



-nente provocan el abandono de cualquier 
programa en curso de ejecución, y reini- 
cralizar el sistema ; vuelven a cargar los 
diversos módulos que componen el 
2P/M, Esta operación recibe el nombre 
de arranque en caliente o "Warm start". 



ASPECTO DE UN COMANDO 



jalquier comando, ya sea del sistema o 
=1 usuario, adopta la forma de conjunto 
je palabras o cadenas de caracteres alfa- 
luméricos, separadas por espacios en 
Dlanco, y que terminan obligatoriamente 
Dn un retroceso de carro (acción sobre la 
recia RETURN). La primera palabra, loca li- 
rada a continuación del "prompt" del sis- 
tema, representa al comando propia- 



Control directo desde el teclado 



Durante la introducción de los comandos 
pueden cometerse errores; de ahí que sea 
imprescindible disponer de una 
herramienta que permita modificar los 
comandos incorrectos antes de concluirlos 
con la orden del retroceso de carro ÍCR). Tal 
posibilidad la brindan los diversos 
caracteres de control que apoyan la edición 
de comandos. 

Estos caracteres especiales son 
combinaciones de la tecla CONTROL con 
ciertas teclas alfabéticas (letras), y 
permiten al usuario un control limitado de 
las operaciones que realice en el terminal. 
La tabla adjunta relaciona algunos de los 
caracteres de control más frecuentes. 
Ciertos caracteres de control son 
aceptados por el sistema en cualquier 
momento — por ejemplo: <CTRL-H> J 
<CTRL-C> i <CTRL-S>. . .— , no sólo en el 
intervalo de tiempo que media entre el 
comienzo de la entrada del comando y la 



pulsación de <CR>, que pone fin a la 
introducción de la orden en ¡a máquina, 
activando su ejecución. 



CARACTERES DE CONTROL DEL CP/M 

<CTRL-H> B o rra el ca ráete r a n terior al 
cursor. 

<CTRL4J> Borra una línea completa 
<CTRL-M> Equivalente a <CR>. 
<CTRL-E> Indica que el comando 

continúa en la línea siguiente. 
<CTRL-S> Congela la impresión sobre la 

pantalla. 

<CTRL-Z> Indica fin del fichero, 
<CTRL-C> Carga el sistema operativo 

por medio de un arranque en 

caliente. 
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mente dicho; tas palabras que lo siguen 
son los argumentos o parámetros asocia- 
dos al comando. Por ejemplo: 
A> ED TEXTO. SAS 
contiene eí comando ED r qu9 ordena la 
edición de un fichero, completado con el 
aigumento TEXTO. BAS (nombre del fi- 
e:;'t e que debe actuar ei editor). 
ds comandos que no actúan 
■ "^:"? "t-;- sobre un fichero; debido a 
t : t :.-e: se contar con una bueña nor- 
malización que permita hacer referencia a 



un fichero eliminando toda posible ambi- 
güedad 

El formato completo que identifica a un 
fichero consta de una referencia al disco a! 
que pertenece, seguida por el nombre del 
fichero y el tipo de fichero. El carácter 
"dos puntos" (:) se utiliza para separar la 
referencia al disco del nombre del fichero 
y el "punto" (.} para separar eJ nombre del 
tipo. Por tanto, la referencia: 
B:NOMBRE.BAS 

identifica a un fichero contenido en el 



disco B, denominado NOMBRE y que pe"- 
tenece a un tipo de ficheros (BAS) c.-i 
característica es que son programa 5 
fuente escritos en lenguaje BASIC. 
No siempre es necesario describir ex- 
haustivamente el fichero utilizado, ya que 
el sistema operativo toma por defecto los 
valores no definidos, e incluso permite 
omitir alguno de los identificadores sin 
que por ello se genere un mensaje de 
error. Por lo que respecta al disco, el sis- 
tema operativo toma por defecto el discc 
que aparece en la petición del sistema. 
El nombre del fichero siempre es necea- 
rlo definirlo, aunque afgunos sistemas 
operativos permiten referencia r al fichero 
cuyo nombre y tipo son nulos. Á su vez r e 
tipo puede omitirse siempre que no sea 
exigibie (tal es el caso de los compilado- 
res); en ciertas ocasiones puede tomarse 
el tipo por defecto, como, por ejemplo 
cuando se hace referencia a un comande 
no residente o transitorio y no se especi- 
fica que ei tipo debe ser ejecutable 

Los identificadores de fas diversas unida 
des de disco disponibles coinciden con las 
primeras letras del alfabeto. La primera 
unidad, utilizada generalmente como "al 
macén" externo del propio sistema opera 
tivo, se nombra con la letra "A"; éste 
corresponde al disco número "0". La letra 
"B" designa al disco cuyo número es e 
"1", y así sucesivamente, pudiendo llega 
hasta el disco número "15", al que corres- 
ponderá la letra "P". 
El empleo de este método de identifica 
ción por parte de los distintos fabricantes 
no está del todo normalizado. Hay fabri 
cantes que reservan las tetras finales de! 
alfabeto ("M", "N JJ , "O" o "P") para de 
signar a las unidades de disco rígido y des 
tinan los primeros caracteres alfabéticos 
("A" "B", "C" r o "D"} a discos flexibles. 
El cambio de disco sobre el que se actúa 
se consigue fácilmente sin más que indi 
car, detrás del "prompt" del sistema, la 
referencia del nuevo disco al que se desea 
acceder seguido por el signo "dos pun- 
tos". Por ejemplo: 
A> C : 

A raíz de la ejecución de esta orden, se 
modificará el "prompt" o indicador de pre- 
sencia del sistema. Este reflejará el cam- 
bio de disco ordenado: 

C> 

A partir de este instante, el disco C será 
considerado como disco de trabajo hasta 
que el sistema operativo reciba una indi- 
cación en contra. 




El módulo BIOS es el brazo ejecutor de las órdenes que dirige la máquina o la zona física de 
ios periféricos que dependen de su con t roí. 




ISCO ES 



La misión del módulo CCP es facilitar ía comunicación directa del usuario con la máquina: 
una comunicación que se establece por medio de las órdenes o comandos. 
Un comando consta de dos zonas fundamentales: ía primera expresa la acción a realizar (por 
ejemplo TYPE), mientras que la segunda especifica el objeto <} elemento destinatario {le la 
acción (archivo HOJA, de tipo BAS y residente en el disco B). 



96 



Aplicaciones 

! Tratamiento de textos 

Qué es, cómo funciona y qué ventajas aporta 
el proceso de textos automatizado 



fc 1 tratamiento manual de pala- 

Ebras para la edición de cartas, 
documentos, informes, con- 
tratos o cualquier otro tipo de 
texto, es un proceso caro; tanto por el 
tiempo a invertir en la producción del 
¡texto escrito como por su importe econó- 
mico. En el mundo profesional y empresa- 
'al, este coste se ve multiplicado por la 
vorágine informativa que ha hecho "au- 
mentar de forma vertiginosa el número de 
originales y copias a manejar 
"orno en otros muchos campos de activi- 
:ad, la solución más rentable y eficaz para 
educir tiempos y coste ha sido mecanizar 
~ tratamiento de textos. En muy pocos 
años, esta actividad ha crecido tan espec- 
tacularmente que, hoy en día, se pueden 
encontrar infinidad de sistemas, basados 
en distintos equipos informáticos, espe- 
:alizados en este tipo de procesos 



¿EN QUE CONSISTE EL 
TRATAMIENTO de TEXTOS? 



-3S operaciones manuales necesarias 
pera producir cualquier texto escrito, an- 
tes de la tlegada de la solución informá- 
tica eran las siguientes: 

Obtención de ¡os datos necesarios 
pera producir el texto. Para elfo se utiliza- 
ra^ archivadores, ficheros, etc. 
Z Redacción del borrador. Una vez reco- 
: ada la información, se escribía un ma- 
"^scríto redactado como primera aproxi- 
mación del texto final, 
] D roducción de! original mecanogra- 
fiado el borrador manuscrito. 

Revisión y corrección de errores me- 
i.r'ográficos. 

! Obtención de copias del escrito on- 



6 Archivo de una de las copias, por si en 
un futuro resultara necesaria para obtener 
información a! respecto. 
En la actualidad; todas estas operaciones 
se pueden realizar con e! apcvc ze ^ 
sistema informático. Veamos cómo se 
efectuarían las seis operaciones sí se opte 
por el empleo de un ordenador capacitado 
para el tratamiento de textos: 
1 . Obtención de datos. En los ficheros 
mecanizados de! ordenador se encerará 
la mayor parte de la informar: : " - ~ - - • • - 
para producir el escrito. 



2. Redacción del borrador. Utilizando un 
formato en el que no se considera aún la 
estética de la presentación, puede elabo- 
rarse la información recopilada para redac- 
tar, fácil y rápidamente, un borrador del 
texto. 

3, Producción del original. En este punto 
será el propio sistema mecanizado el que 
a partir del borrador y varios parámetros 
definitorios dei formato (tipo de letra, lí- 
neas por página, número de caracteres, 
paginación automática, etc.) se encargará 
de preparar el original. 
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TRATAMIENTO 
DE 
TEXTOS 
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PROCESO 

DE 
TEXTOS 




Con eí tratamiento de textos automatizado disminuye e\ tiempo necesario para ¡a producción 
de documentos escritos, mejora ta calidad de ios mismos y se reduce eí coste económico. 



4 Revisión y corrección. Antes de impri- 
mir el texto, se puede observar en una 
pantalla como aparecerá escrito sobre el 
papel; en este instante pueden realizarse 
las oportunas correcciones. 

5, Obtención de copias. Es importante 
señalar que hasta este momento no ha 
sido necesario editar ningún papel escrito. 
Ahora, una vez garantizada la corrección 
del texto, pueden ya obtenerse automáti- 
camente todas las copias que se deseen. 

6. Archivo de una de las copias. Esta es 
una tarea superflua, puesto que el texto 
permanecerá almacenado en la memoria 
de masa del sistema. Un hecho que su 
pone una sustancial economía en cuanto a 
volumen de archivo y manipulación de co- 
pias. 

En definitiva, no cabe duda de que el em- 
pleo de un sistema para el tratamiento de 
textos aporta, además de un ahorro de 
tiempo y dinero, una clara mejora en la 
calidad de los escritos producidos. 

LOS SISTEMAS PARA EL 
TRATAMIENTO DE TEXTOS 



Como ya apuntábamos al principio, exis- 
ten muchos y muy distintos sistemas para 
el tratamiento de textos. A continuación 
se relacionan algunos de los más impor- 
tantes: 



• Máquinas de escribir electrónicas 
Son los sistemas más elementa es para ol 
proceso de textos. Básicamente, son má- 
quinas de escribir tradicionales a las que 
se acopla una pequeña memoria y algunas 
teclas adicionales que introducen ciertas 
funciones: justificación del texto entre 
ambos márgenes, centrado automático, 
alineación por la izquierda o derecha., . En 
algunos casos también incorporan un vi- 
sor para comprobar la corrección del texto 
antes de imprimirlo. 

• Sistemas de máquinas de escribir elec- 
trónicas 

Con objeto de aumentar la memoria dis- 
ponible en cada máquina y hacerla perma- 
nente, pueden conectarse una o varias 
máquinas de escribirá un ordenador Ade- 
más de las funciones de edición propias 
de la máquina, el ordenaaor aportará una 
pantalla para la visual ización de los textos 
y facilitará la comunicación entre los dis- 
tintos "productores de textos". 

• Ordenadores personales con progra- 
mas para el tratamiento de textos 

Sin lugar a dudas, éste es ef sistema para 
el tratamiento de textos más frecuente y 
popularizado. Como su propio nombre in- 
dica, se basa en la asociación de dos ele- 
mentos: 

— Ordenador personal 
Un equipo de moderado tamaño y precio 
útil para realizar los trabajos que tradicio- 
nalmente se reservaban a los grandes or- 
denadores. Los dos usuarios típicos de 
ordenadores personales son los profesio- 
nales independientes y las pequeñas o 



medianas empresas. Ambos usuarios 
suelen tener necesidad de producir nu- 
merosos escritos y pueden obtener nota- 
bles ventajas si deciden utilizar el ordena- 
dor personal para el tratamiento de textos 

— Programa (software) para ei trata- 
miento de textos 

Como ya anticipábamos, el ordenador per- 
sonal puede utilizarse para resolver pro- 
blemas de muy diversa índole. Para cada 
uno de ellos, hay que disponer de uno o 
más programas que serán ejecutados en 
el ordenador tantas veces como desee e¡ 
usuario. Si se opta por utilizar e^ordenador 
personal para realizar el tratamiento de 
textos, será imprescindible contar con el 
software de aplicación adecuado. 
En esta misma sección estudiaremos 
más adelante, los principales paquetes de 
aplicación destinados al procesamiento de 
textos en ordenadores personales. 
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MAQUINAS DE ESCRIBIR 
ELECTRONICAS 



Para éíépúf la productividad de tos sistemas 
basados en máquinas de escribir 
electrónicas, éstas pueden conectarse a un 
ordenador personal de forma que 
compartan los recursos del mismo. 



• Procesadores de textos dedicados 
En algunos casos, para reducir el precio 
del hardware (equipos) y del software 
(programas) se opta por microprocesado- 
res especializados exclusivamente en ef 
tratamiento de textos. La adquisición de 
un equipo específicamente diseñado para 
tal actividad, impide utilizar el hardware 
para resolver otro tipo de problemas. Evi- 
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dentemente, esta solución sólo es reco- 
mendable para empresas con un gran vo- 
lumen de textos a tratar y dotadas de 
otros procedimientos de mecanización 
general. 

• Ordenadores con programas para ef 
iratamiento de textos 
Al igual que puede utilizarse un ordenador 
personal "instruido" por programas para 
si tratamiento de textos, también es posi- 
ble utilizar programas de esta índole con 
otros equipos, como mini-ordenadores e 
; ncluso grandes ordenadores. 
Normalmente, el empleo de grandes or- 
denadores para el tratamiento de palabras 
suele estar reservado a la documentación 
de programas informáticos, ya que resulta 
muy caro dedicar equipos grandes al trata- 
miento de textos. Por ello, lo habitual es 
que las empresas recurran a alguno de los 
sistemas descritos anteriormente, aun en 
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Los ptígueres de aplicación para el 
tratamiento de textos suelen 
adoptar una estructura 
arborescente de mentís. El usuario 
progresa a través de ellos al 
seleccionar las di tersas opciones 
de trabajo* 



Elementos hardware para el proceso de textos 



Para realizar un tratamiento de textos 
automatizado, resulta imprescindible la 
intervención de un procesador. Este es e! 
elemento básico para gestión de rodo el 
conjunto de tareas cuya culminación es la 
edición de un texto. No obstante, sin la 
participación de al menos un periférico 
dedicado a fa entrada del texto original, y 
otro.pa ra la salida del texto ya procesado, ef 
ordenador sería incapaz de comunicarse 
con el usuario. En definitiva, las exigencias 
hardware hacen imprescindible la 
presencia de un procesador [unidad central 
del ordenador}, una unidad de entrada y una 
unidad de salida. 

Con esta configuración mínimo es posible 
almacenar el texto introducido en la 
memoria del ordenador y, una vez tratado, 
reproducirlo a través de una impresora 
(unidad de salida). No obstante, si una vez 
finalizada la sesión se desea obtener una 
nueva copia de un texto introducido en 
alguna sesión anterior, será necesario 
volver a introducir eJ texto en su totalidad. 
Para solucionar este inconveniente, es 
preciso disponer de una unidad para el 
almacenamiento permanente de la 
información (los textos en el caso que nos 
ocupa). Este cometido queda 
encomendado a los periféricos de 
almacenamiento o memoria de masa 
asociadas a( ordenador. Su presencia 
permite ya disponer de una configuración 
completa, con los elementos hardware 
típicos e imprescindibles para realizar con 
propiedad el tratamiento de textos 
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Esta breve síntesis, cabe completarla 
citando algunas de las vanantes que 
pueden adoptar los distintos elementos 
hardware del sistema. 

1 Procesador 

Puede utilizarse desde un ordenador 
personal de cualquier categoría, hasta un 
ordenador de g ra n tamaño ; si bien, hay que 
constatar que corresponde un mayor 
protagonismo a los ordenadores 
personales. 

2. Unidades de entrada/salida 

Tanto para introducir los textos originales, 
como para comunicar al usuario los 



resultados provisionales del tratamiento, 
suele utilizarse un terminal (teclado más 
pantatla). La entrada se realiza a través del 
teclado, mientras que la salida adopta la 
forma de presentación en pantalla. 
El periférico de salida adecuado para editar 
el texto definitivo es la impresora de papel. 

3. Unidades para el almacenamiento 
permanente 

En este punto son varias las alternativas: 
discos magnéticos de tipo rígido (muy 
adecuados por su eíevada capacidad y 
velocidad de acceso para recoger datos de 
forma permanente), los tradicionales discos 
flexibles, o incluso simples casetes 
convencionales. 
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£¿*í modernos ordenadores personales han irrumpido en el ámbito del tratamiento de textos, 
aportando comodidad y eficacia respecto a los medios tradicionales. 



5 :eso de que ya dispongan de un gran 
centro de proceso de datos 

¿COMO FUNCIONA UN SISTEMA 
PARA EL TRATAMIENTO 
DE TEXTOS? 



-' método habitual se plasma en una es- 
tructura arborescente de «menús»; éstos 



permiten al usuario ir tomando las decisio- 
nes que van a marcar el funcionamiento 
del programa. Cada "menú" consiste en 
un formato, visualizado en la pantalla, a 
través del que el sistema ofrece al opera- 
dor un abanico de posibilidades para que 
decida cuál de elfas desea ejecutar. Op- 
cionalmente cada "menú" puede incorpo- 
rar una explicación de los resultados que 
se producirán según la opción elegida; en 
este último caso, se dice que el sistema 
dispone de TUTOR o de apoyo "HELP" 
para facilitar su manejo. 



MAIN MENU 



El "menú" principal es el que aparece i 
mediatamente después de invocar o "I 
mar" al sistema de tratamiento de texto 
con frecuencia, suele recibir el nombre 
"MAIN MENU", Al elegir alguna de s 
opciones, debe aparecer en pantalla 
nuevo menú, al que se denomina "SU 
MENU" (menú secundario), que ofre 
nuevas posíbifidades dentro de la opcr 
seleccionada. 

En cualquiera de los menús- ya citad 
(HELP MENU, MAIN MENU o SUBME 
NUS) r existe una última línea de común 
cación a la que se denomina PROMPT. 
través de ella el sistema se comunica c 
el usuario. Por ejemplo, si en un submen ' 
existen las opciones A, B, C y D y el usu 
rio pulsa la letra E, que no corresponde 
ninguna de las opciones existentes, en 
fínea PROMPT aparecerá un mensaje d 
siguiente estilo: "LA OPCION <E> 
DESCONOCIDA". 

También es muy frecuente, cuando se uti- 
liza una opción para la edición de texto por 
pantalla, la existencia de dos o tres líneas, 
situadas en la parte superior de Ja pantalla 
en las que se indican las características de 
la situación en que nos encontramos. En 
la primera de ellas suele referenciarse la 
opción en la que se encuentra el sistema, 
el título del documento r el espacio dispo- 
nible, etc. Las siguientes, suelen estar 
ocupadas por una "cabecera" que sirve 
para identificar la posición del cursor (fila y 
columna en [a que se puede escribir). 



1 FORMATEAR 

2 EDITAR 

3 ESCRIBIR 1 

4 COPIAR 

5 BORRAR 

6 CLASIFICAR 

7 COMUNICACIONES 

8 FINALIZAR 



SUB MENU "ESCRIBIR 1 ' 

INFORME COMPLETO 
INFORME PARCIAL 
FORMULARIO ESPECIAL 
CANCELAR ESCRITURA 
FIN ESCRITURA 



El menú principal ( main mena) ofrece las opciones generales que sintetizan las 
posibilidades del tratamiento de textos. Cada ana de sus opciones da paso al correspondiente 
s u b me nú cuya finalidad es precisar la actividad elegida. 



UNA BREVE SINTESIS 



En este primer capítulo dedicado a los 
sistemas para el tratamiento de textos se 
ha contestado sucintamente a tres pre- 
guntas de carácter general: ¿En qué con- 
siste el tratamiento mecanizado de tex- 
tos?, ¿cuáles son los principales tipos de 
sistemas para el tratamiento de textos? y 
¿cómo funciona un sistema para el trata- 
miento de textos? En próximos capítulos 
se estudiarán con detalle las principales 
aplicaciones que existen en ef mercado 
informático para el tratamiento de textos 
en ordenadores personales, 
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Edición de programas 

Escritura, corrección y puesta a punto 
de programas BASIC 



o largo de los capítulos prece- 
dentes se han presentado al- 
gunos de los comandos que 
forman parte de! vocabulario 
del lenguaje BASIC. Comandos cuyo obje- 
tivo es construir las instrucciones que da- 
rán cuerpo a los programas destinados a 
'educar" al ordenador. En este punto de 
a obra cabe plantearse un interrogante: 
xómo hay que escribir los programas de 
-orma que se aprovechen al máximo las 
posibilidades de edición que brinda el BA- 
SIC? 

zs evidente que el método utilizado hasta 
ahora resulta eficaz: escribir las instruc- 
ciones deseadas y, al fina! de cada línea, 
□ulsar la tecla correspondiente al retro- 
-eso de carro (RETURN o EMTER). Sin 
embargo, no cabe duda que semejante 
Drocedimiento no es generalizare... ¿Qué 



sjjcede si se teclea algo mal? Aquí es 
donde entra en juego una de las herra- 
mientas que brinda el ordenador para faci- 
litar las tareas de programación; el editor. 
Esta es una zona r habitual mente incorpo- 
rada al traductor de lenguaje BASIC ce 
agrupa a un cierto número de funciones 
para facilitar la escritura y corrección de 
programas. 

Existen varios tipos de editores que ofre- 
cen un mayor o menor número de funcio- 
nes y ponen en práctica diversos métodos 
de edición. 

Antes de pasar a su estudio, es conve- 
niente dar un repaso a los procedimientos 
de edición más elementales, compartidos 
por cualquier ordenador abierto al diálogo 
en BASIC. 

El procedimiento más obvio y elemental 
para corregir el error cometido en una lí- 



PRQGRAMA 



nea de programa consiste, sencillamente, 
en escribir de nuevo la línea en cuestión. 
£ introducir una línea de programa prece- 
dida por un número utilizado anterior- 
mente, la nueva línea reemplazará a la 
anterior; en consecuencia, la nueva línea 
que incorpora la corrección pertinente, 
reemplazará a su homologa errónea. 
Este mismo método es perfectamente 
utílizab!e para borrar líneas de programa. 
Si se introduce únicamente el número de 
línea, el ordenador borrará la línea cuyo 
número coincida con el introducido. En 
efecto, la acción equivale a reemplazar la 
línea anterior por la nueva, desprovista de 
contenido. 

La eficacia de este método elemental es 
indudable tal como evidencia el siguiente 
trabajo de edición. 



ESCRITURA DE UN PROGRAMA 



La sesión de trabajo de un programador 
empieza, ineludiblemente, con la intro- 
ducción del programa. Un programa que 
puede ser tan sencillo como el que apa- 
rece en la pantalla: 




no 




El 



500 



LINEAS DE 
PROGRAMA 





La escritura, corrección y puesta a punto de (os programas son tareas englobadas en el 

partado de "edición". Esta es una actividad apoyada por el propio traductor de lenguaje 
BASIC, a través de las denominadas herramientas de edición. 
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PROGRAMA EDITADO 




El procedimiento más elemental para la corrección de errores es el que refleja el gráfico 
adjunto. Para corregir una línea de programa, basta con reescribirla precedida por el mismo 
número. Si se trata de borrarla , será suficiente con escribir su correspondiente 
numero de línea seguido por una acción sobre la tecla RETURN, 



En efecto, el error se ha subsanado: 
palabra DATO de la línea 20 aparece 
corregida. 

Un nuevo repaso al programa puede deci- 
dir al programador por la supresión de la | 
línea 30, cuya presencia es redundante. 
De nuevo, puede aplicarse el mismo pro- 
cedimiento: escribir una nueva línea de 
programa precedida por el mismo nú- 
mero. En este caso, como quiera que i 
trata de eliminar su presencia, basta or 
escribir sólo el número de la línea afectada! 
y pulsar la tecla RETURN a continuación. 
El resultado queda patente al utilizar uns 
vez más el comando LIST: 



30 (CR) 



LIST 

10 ENTRADA DE DATOS 

20 INPUT "DATO 1"; A 

40 PRINT "EL PRIMER DATO ES: 




Cuatro líneas de programa cuya introduc- 
ción se ha realizado ordenadamente y po- 
niendo en práctica la misma secuencia en 
cada caso: tecleare! correspondiente nú- 
mero de línea, su contenido y, por último, 
darla por concluida con una acción sobre 
la tecla de retorno (RETURN o ENTER). 
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DESPLAZAMIENTO 
DEL CURSOR 

Uno de las tres tipos básicos de editores es 
el de "pantalla". El usuario puede 
desplazarse a cualquier punto de la misma 
utilizando las teclas para el desplazamiento 
del cursor. Una vez. colocado el cursor, 
puede ya introducir las oportunas 
mod ifi ca clones , 



El programa está ya en el interior de la 
máquina y puede ordenarse su ejecución 
con la orden RUISL Sin embargo, es conve- 
niente comprobar antes su corrección. 
Tal como suele ocurrir con frecuencia, se 
ha deslizado un error en su introducción; 
un error casi inapreciable (una letra alte- 
rada en la línea 20), pero suficiente para 
inutilizar la eficacia práctica del programa. 
¿Cómo corregirlo? Aplicando el procedi- 
miento de edición más elemental, será 
preciso escribir de nuevo la línea en cues- 
tión, esta vez procurando que no se repita 
el error. 

La línea escrita, cuyo número coincide con 
el de la que incluía el error, sustituirá a 
aquella en la memoria del ordenador. Esta 
circunstancia es fácilmente comprobable, 
sin más que ordenar la presentación en 
pantalla del listado por medio del co- 
mando LIST: 



20 INPUT "DATO 1"; A 
LIST 

10 REM ENTRADA DE DATOS 

20 INPUT "DATO 1"; A 

30 PRINT "DATO 1"; A 

40 PRINT "EL PRIMER DATO ES: 



EDITORES DE PROGRAMAS 



Una sesión de trabajo como la relatada en 
el apartado precedente puede convertirse 
■en una tarea prolongada y tediosa. Nor- 
malmente, los programas a editar serán 
mucho más extensos y sus instrucciones 
bastante más complejas. En tal caso, es 
obvio que la repetición del contenido total 
de las líneas a modificar no será una activi- 
dad grata ni eficaz, 

Afortunadamente, la mayor parte de los 
traductores de lenguaje BAStC disponen 
de herramientas auxiliares para corregir 
errores y realizar modificaciones con ma- 
yor comodidad y rapidez, EJ conjunto de 
medios que brinda el ordenador para la 
edición de programas recibe el nombre de 
editor. 

Existen muchos tipos de editores, dife- 
renciados por su potencia y por las posibi- 
lidades que ponen a disposición del pro- 
gramador. En todo caso, el aprendizaje del 
manejo del editor es de suma importancia 
a la hora de adquirir un ordenador y di spo- 
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Da paso al editor. Permite modificar ei contenido de las líneas de programa. 

Formato: EDIT [< número de línea>] 

Ejemplos: EDIT 

EDIT 30 



-erse a confeccionar programas para el 
mismo. 

En muchos ordenadores está permitido 
-ealizar modificaciones y corregir errores 
ieditar) inmediatamente después de ha- 
ber listado la porción afectada del pro- 
grama. Normalmente, se puede accederá 
3 línea deseada accionando las teclas 
para el desplazamiento del cursor. Una 
vez posicíonado el cursor se procede a 
codificar la línea, ya sea insertando carac- 
reres o bien realizando una nueva escri- 
:ura encima de la zona a corregir. Después 
ae realizar los cambios pertinentes, basta 
con pulsar la tecla RETUHN en cualquier 
punto de la línea para que se haga definí- 
iva la modificación realizada. 
Este tipo de editor se denomina "fu II 
screen" o de pantalla completa, debido a 
:je la edición puede realizarse en cual- 
quier punto de la pantalla. 
Los editores de pantalla presentan algu- 

as limitaciones en ciertos casos. Por 
eemplo, hay equipos que permiten intro- 
ducir caracteres de controf dentro del 
texto asociado a una instrucción PRINT; 
caracteres que se obtienen directamente 
~edíante el uso de las teclas del cursor y 
: vas especíales, De esta forma, cuando 
se está escribiendo una constante alfanu- 
^erica (ello viene señalado por las comi- 
las que preceden al texto escrito), las te- 
ras del cursor no realizarán la acción p re- 
vista r sino que escribirán el carácter de 
control correspondiente. Ello impedirá el 

ore movimiento del cursor en dicha zona. 
í iros ordenadores incorporan un se- 
rondo tipo de editor; el denominado edi- 
:jr de líneas, cuya actividad está regida 
Dor el comando EDIT. En este caso, sólo 
es posible editar la línea seleccionada por 
t i\o del comando EDIT. La selección se 

tí za colocando el número de la línea a 
-.liar tras el referido comando, A conti- 
■xtación, pueden ya realizarse las corree- 
renes oportunas, apoyándose en el re- 

- _ :no de subcomandos del editor. 



EL COMANDO EDIT 



EDIT es el comando básico entorno al que 
se organiza el funcionamiento del editor 
de líneas. Al ejecutarlo, se accede al deno- 
minado modo de edición: situación que 
permite operar las modificaciones nece- 
sarias en ¡a línea de programa seleccio- 
nada. 

El formato de una instrucción del tipo 
EDIT es el siguiente: 

EDIT <número de línea> 

El número de línea debe coincidir con el 
de la línea de programa a editar. 
Tras la ejecución de este comando, la lí- 
nea seleccionada entra en modo edición. 
Algunos editores de líneas muestran la 
línea indicada en la zona inferior de la pan- 
talla, lista para su edición. En otros, única- 
mente aparecerá el número de la línea de 
edición y el cursor situado inmediata- 
mente después. Acto seguido, será nece- 



sario seleccionar una de las diversas op- 
ciones de edición disponibles. 
El editor de líneas exige teclear el co- 
mando EDIT cada vez que se desee editar 
una nueva línea. No obstante, una vez que 
se ha entrado en modo edición se permite 
el libre movimiento del cursor a través de 
Ja línea seleccionada. En esta situación, 
algunas teclas específicas dan paso a las 
funciones de inserción, borrado o sustitu- 
ción de caracteres. 

EL EDITOR DE "BUFFER" 



Existe un tercer tipo de editor, tal vez el 
más primitivo de los mencionados. 
Para manejarlo es preciso situarse al prin- 
cipio de la línea a editar (en cualquier 
punto de la pantalla), e ir "copiando" los 
caracteres en un "buffer" o memoria 
temporal. Esto se consigue "pasando por 
encima" de los mencionados caracteres 
con el cursor. A medida que se van dando 
las órdenes adecuadas se consigue la in- 
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EDIT 20 



El editor de "líneas" 
reduce el campo de 
ir ahajo a ta línea 
seleccionada por medio 
del comando EDIT. La 
modificación de su 
come nido se realizará 
desplazando el cursor a 
lo largo de la misma y 
utilizando los oportunos 
subcomandos de 
edición. 



DESPLAZAMIENTO 
DEL CURSOR 
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sardón o el borrado de los caracteres ne- 

cesarios. 

8 principal inconveniente de los editores 
__e zan buffer es la necesidad de re- 
::ca la línea. Esta característica 
:z :e ^ egar al final de la misma antes de 
poder accionar la tecla RETURN. 
:t - r a _ :e imperativo deriva de la forma 
en ta que se aceptan los caracteres en 
aídón. El editor dispone al efecto de una 
; de memoria denominada "buffer", 
de la cual se extrae la línea editada al 
: : : jit el proceso de edición accionando 
a tecla RETURN. 

Para introducir caracteres en el buffer es 
necesario pasar el cursor sobre ellos. Si se 
:eciea algún carácter nuevo, éste entrará 
en el buffer inmediatamente. La inserción 
o sustitución de caracteres se habilita por 
medio de las teclas de desplazamiento del 
cursor, posicionando a éste en el lugar 
adecuado. Ello permite saltar porciones 
de la línea que no serán introducidas en el 
buffer. No cabe duda que este método de 
edición exige una profunda concentración 
por parte del programador; éste ha de 
llevar en mente los caracteres introduci- 
dos en el buffer. 

LA DIVERSIDAD 
DE LOS EDITORES 



Son varios los tipos de editores de progra- 
mas que cabe encontrar en distintos orde- 
nadores. Salvando las peculiaridades que 
pueden presentar editores de un mismo 




Activa el modo de numeración automática de líneas. 

Formato: AUTO [<número de finea>[ t <incremento>]] 

Ejemplos: AUTO 

AUTO 10 
AUTO 50 JO 



tipo, cabe considerar los tres grupos bási- 
cos definidos hasta el momento: 

— Editores de pantalla (totales o "full 
screen"). 

— Editores de líneas. 

— Editores de "buffer" o memoria tem- 
poral. 

En general, el editor de uso más fácil es el 
de pantalla, puesto que permite una edi- 
ción inmediata. Permite corregir cualquier 
instrucción presente en pantalla sin más 
que accionar la tecla de retroceso de carro 
tras realizar las correcciones oportunas. 
Los editores que utilizan un buffer son los 
más incómodos y cuyo empleo es menos 
inmediato; no obstante, una vez que su 
manejo resulta familiar constituirán tam- 
bién una eficaz herramienta de trabajo. 
Los editores de línea son, en principio, los 
menos potentes; sin embargo, de ellos se 
puede conseguir mucho más de lo que 
parece a primera vista. Existen muchas 
variantes, aunque, por lo general, hay que 
entrar en el modo de edición por medio de 
una orden especifica (normalmente EDIT). 
Al margen del tipo de editor que incorpore 
cada dialecto BASIC, existen ciertos co- 



c 



EDITOR DE BUFFER 



3 




El editor menos 
evolucionado y más 
incómodo paro el 
usuario es el de 
'buffer" . Las caracteres 
de la línea en edición 
barridos por el cursor, y 
las modificaciones 
introducidas, se copian 
en una memoria 
temporal. El contenido 
de esta última será 
aceptado como 
definitivo al accionar la 
tecla RETURN o 
ENTER. 



VALIDACION 

DEL BUFFER 



DESPLAZAMIENTO 
DEL CURSOR 



mandos de apoyo a las tareas de edición 
de programas que pueden estar presen- 
tes en distintos equipos. Este grupo de 
comandos resultan adecuados para nu- 
merar automáticamente las sucesivas lí- 
neas de un programa en edición, para su 
renumeración automática, o para el bo- 
rrado directo de líneas de programa, 

EL COMANDO AUTO 



A menudo resulta tedioso el hecho de 
tener que teclear el número de línea 
cuando se introduce un programa por vez 
primera. Incomodidad que aumenta a me- 
dida que el programa es más extenso. 
Para facilitar esta tarea, algunos traducto- 
res BASIC disponen del comando AUTO. 
El referido comando libera al usuario de la 
necesidad de llevar la cuenta de los núme- 
ros de línea, puesto que se encarga de 
numerar las líneas a medida que se intro- 
ducen, calculando el número correspon- 
diente a cada línea sucesiva. 
EJ formato de una instrucción construida a 
partir del comando AUTO es el siguiente; 

AUTO [<número de línea>[ f < incre- 
mento^] 

Una vez ejecutado en modo directo, el 
ordenador generará de forma automática 
el número de linea correspondiente tras 
cada acción del programador sobre la te- 
cla de retroceso de carro (CR). 
AUTO comienza la numeración del pro- 
grama a partir del número indicado en el 
argumento: <número de línea >. Este va- 
lor crecerá en las sucesivas líneas en el 
número de unidades que se hayan indi- 
cado en la zona de <incremento>. 
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auto 



Cuando la instrucción AUTO se formula 
desprovista de argumento, el ordenador 
considera que ambos valores (<número 
de línea > e <incremento>) adoptan el 
valor 10. Por ello, numerará el programa a 
partir de la línea 10 y en sucesivos incre- 
mentos de 10 unidades. 
Si el < número de línea > va seguido por 
jna coma y no se especifica el incre- 
mento, se entiende que el valor del incre- 
mento es igual al incremento indicado en 
el último comando AUTO ejecutado con 
anterioridad. 



meros de dos líneas consecutivas difieren 
en una sola unidad. 

Ambas situaciones hacen aconsejable 
—cuando no obligan — a ^enumerar" las 
líneas del programa; esto es; a cambiar 
los números de las líneas sin alterar el 
orden de las mismas, 
El comando utilizable a tal efecto es RE- 
NU rvl Este permite sustituir [os números 
de línea contiguos por otros nuevos, es- 
pecificando, además, eJ salto deseado en- 
tre cada dos números consecutivos. Su 
formato general es: 

RENUM [[<nuevo>][,[<anterior>]- 
[ r <incremento>]]] 

Como se ha indicado, su misión es Ja de 
sustituir los números de línea situados a 
partir del indicado en la zona <anterior>, 
hasta el final del programa, por los núme- 
ros <nuevo> y sucesivos, en saltos de 
tantas unidades como especifique ta zona 
de < incrementos 

El número indicado en el campo <ante- 



ríor> hace referencia al primer número de 
línea a sustituir. Semejante precisión per- 
mite renumerar sólo una parte del pro- 
grama, manteniendo en otras zonas la nu- 
meración de líneas original. 
El siguiente ejemplo ilustra la actuación de 
este tipo de instrucciones. El objeto de 
trabajo es un simple programa capaz de 
calcular el cuadrado del número que se 
introduzca como respuesta a la instruc- 
ción INPUT, El programa finalizará al reci- 
bir un cero como dato de entrada. 



10 REM COMANDO RENUM 

20 PRINT "PROGRAMA EJEMPLO" 

21 INPUT A 

22 ff A=0 THEN GOTO 158 

23 LET B=A*A 

122 PRINT "EL CUADRADO DE";A 

157 PRINT "ES:";B 

158 END 



a COMANDO RENUM 



- la hora de intentar pulir y perfeccionar 
jn determinado programa BASIC, es fun- 
damental entender la función de cada 
zona del mismo, así como las relaciones 
entre ellas. Para ello no basta con conocer 
a fondo el lenguaje. Muchas veces, la 
complejidad de su estructura no permite 
jn seguimiento fácil de la ejecución, 
la inserción de comentarios (REM) suele 
aclarar el cometido de los distintos frag- 
mentos del programa. Otro método clarifi- 
cador consiste en agrupar las lineas del 
: agrama en bloques fraccionados. Por 
ejemplo, una cierta rutina o zona de cál- 
ulo específica se puede situar en las lí- 
neas 2000 y siguientes, otra a partir de la 
3000, etc. Posteriormente, será posible 
centificar las distintas partes del pro- 
Tama atendiendo exclusivamente a las 
limeras cifras de los números de línea, 
-abituafmente, las lineas intercaladas 
: retribuyen al desorden general, alte- 
lando la pauta de numeración. En deter- 
~ nados casos, incluso se hace imposible 
nsertar una nueva tínea: cuando los nú- 



Subcomandos del editor 
de líneas 



Los editores de líneas suelen disponer de 
un conjunto de subcomandos que facilitan 
la edición de la línea en curso. Estos 
subcomandos se detallan a continuación, 
agrupados de acuerdo a la Función que 
realizan: 

CURSOR 

Espacio. Mueve el cursor un lugar hacia la 
derecha, mostrando el carácter que ocupa 
dicha posición en la linea original. 

INSERCION 

L Permite insertar tantos caracteres 
como se desee a partir de la posición en fa 
que esté situado el cursor. Para salir de 
esta opción es necesario pulsar la tecla 
ESCAPE. 

X. Extensión de línea, Desplaza el cursor 
al final de la línea y entra en inserción en 
ese punto. 

BORRADO 

D: B o rra el ca ráete r situado en la pos ic íó n 
siguiente a la que ocupa el cursor. 



H; Borra todos los caracteres situados a 

la derecha del cursor y entra 

automáticamente en modo inserción. 

S. Va acompañado de un número y un 

carácter. Buscará el carácter indicado 

tantas veces como señale el número 

introducido y colocará el cursor delante del 

carácter afectado. 

K: Actúa de forma análoga al 

subco mando S, si bien, borra todos los 

caracteres por los que pasa. 

SUSTITUCION 

C: Sustituye el carácter situado a la 
derecha del cursor por el que se introduzca 
a continuación de C; puede acompañarse 
por un parámetro que indicará el número de 
caracteres contiguos a sustituir. 

FINAL 

(CRJ: Señala el final del proceso de 
edición; al accionar la tecla en cuestión 
ÍRETURN o ENTER) el ordenador aceptará 
todos tos cambios realizados. 
E: Salida de [as modificaciones 
introducidas. 

L: Lista la línea en curso y entra en 
edición la siguiente. 
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Ren uniera líneas de programa. 

Formato: RENUM \[<número nuevo>] l[<número antiguo] [,<incremento>JU 

Ejemplos: RENUM 100 

RENUM 100,10 
RENUM 100,10,5 



renum 




jo] REM 50FT 



20 PAPER 10 



100 BORDER 5 
110 CLS 



Un programa de indudable sencillez, pero 
que ganaría en claridad con la inserción de 
algunos comentarios. 
El problema surge en la peculiar numera- 
ción de sus líneas, ¿Cómo es posible em- 
plazar una instrucción entre las lineas 20 y 
21 r o entre la 21 y 22? No queda más 
alternativa que abrir espacio entre las 
mencionadas líneas; una solución que el 
comando RENUM pondrá en práctica de 
forma inmediata y automática: 



RENUM 100,21,2 
LIST 

10 REM COMANDO RENUM 
20 PRINT "PROGRAMA EJEMPLO" 
100 INPUTA 

102 IF A=0 THEN GOTO 110 
104 LET B=A*A 

106 PRINT "EL CUADRADO 0E J, ;A 
108 PRINT "ES:";B 
110 END 



20 REM SOFT 

60 FOR A=1 T0 100 

85 LET U-\HJ 

100 OUT 2W , N 

136 NEXT A 



RENUM 200,20,5 210 LET N = INT 





200JREM SOFT 
2051 FOR A=l T0 100 



215 | OUT 254 , N 
220lNEXT A 



PROGRAMA ORIGINAL 



PROGRAMA RENUMERADO 



Re numeración automática de un programa por efecto de una instrucción RENUM, 



La instrucción RENUM formulada, ordena 
la remuneración de la zona de programa 
situada a partir de la línea 21. La nueva 
numeración debe partir del número de lí- 
nea 100 y distribuirse en sucesivas líneas 
cuyos números se distancien en incre- 
mentos de 2 unidades. La ejecución de 
una orden LIST permite observar la nueva 
distribución de números de línea. 
Ahora es posible ya emplazar nuevas ins- 
trucciones precediendo a las instruccio- 
nes INPUT e IF/THEN. Por ejemplo: 

95 PRINT "INTRODUZCA UN NUMERO" 

101 REM DETECCION DE FIN DE PROGRAMA 

LIST 

10 REM COMANDO RENUM 
20 PRINT "PROGRAMA EJEMPLO" 
95 PRINT "INTRODUZCA UN NUMERO" 
100 INPUTA 

107 REM DETECCION DE FIN 0E PROGRAMA 

102 IF A=0 THEN GOTO 110 
104 LET B=A*A 

106 PRINT "EL CUADRADO DE";A 

108 PRINT "ES:";R 
110 END 

Un nuevo uso de RENUM permitirá remo- 
delar ta numeración de líneas logrando 
una distribución consecutiva en saltos de 
diez unidades: 

RENUM 30,95 JO 
LIST 

10 REM COMANDO RENUM 
20 PRINT "PROGRAMA EJEMPLO" 
30 PRINT "INTRODUZCA UN NUMERO" 
40 INPUTA 

50 REM DETECCION DE FIN DE PROGRAMA 
60 1FA=0 THEN GOTO 100 
70 LET B=A*A 

80 PRINT "EL CUADRADO DE";A 
90 PRINT "ES:";B 
100 END 

El programa está ya completo y organi- 
zado con la colaboración del comando RE- 
NUM. Un comando cuya actuación va más 
allá de la simple modificación de los nú- 
meros que preceden a las líneas de pro- 
grama. Como puede observarse a lo largo 
de las sucesivas operaciones de enume- 
ración, e! propio RENUM se ha encargado 
de actualizar el número de línea al que 
debe realizarse el salto ordenado en la 
instrucción IF/THEN (línea 22 del listado 
original). En cada caso, el número de línea 
asociado a la zona GOTO ha adoptado la 
referencia de la instrucción END. 
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TABLA DE CONVERSION 


ORDENADOR 


EDIT 


AUTO 


RENUM 


DELETE 


Eorr ni> 


AUTO <nl> f <inc> 


RENUM <nue.>, <ant.>, 
<inc> 


DELETE <inic>— <fin.> 


APPLE II (APPLESOFT) 








DELETE <inic>-<fin.> 


APRICOT (M-BASIC) 


EDIT <nl> 


AUTO <nl>, <íkl> 


RENUM <nue > r <ant>, 
<inc> 




ATAR1 











CBM 64 


— 


— 




DEL <imc>-<fm> 


DRAGON 


EDIT <nl> 




RENUM <nue> r <ant>, 
<inc> 


DELETE <mic>-<fin/> 


EQUIPOS JV1SX 


— 


AUTO <nl>, <bíkl> 


RENUM <nue.>, <ant>, 
<éeic.> 


DELETE <¡nic>-<fin.> 


HP-150 


EDIT <nl> 


AUTO <nl>, <mc> 


RENUM <nue,>, <ant> f 
<inc> 


DELETE <inic>^<fin.> 


IBM PC 


EDIT <nl> 


AUTO <nl>, <ikl> 


RENUM <nue >, <anL>, 
<inc> 


DELETE <inic>— <fin.> 


N1PF 








DEL <imc>— <fin.> 


NCR DNI-V (MS-BASÍC) 


EDIT <nl> 


AUTO <ní> r <inc.> 


RENUM <nue,>, <ant>, 
<inc> 


DELETE <inic>-<fin\> 


NEW BRAIN 








n Fl FTF -¿^irjio *r"fin 

UCLCIC ^. l M l L_ ^iiii,^* 


ORIC 


EDIT <nl> 


AUTO <nl>, <inc> 






SHARP MZ-700 {MZ-BASIC] 




AUTO <nl>, <tnc> 


RENUM <nue>, <ant.> J 
<inc> 


DELETE <inic>-<fin.> 


SINCLAIR QL 


EDIT <nl> P <ínc> (1) 


y AUTO <nl>, <inc> 


RENUM <ínic>TO<fin.>; 
<nue,>, <ínc> ÍU 


DLINE <¡n¡c>T0<fin> (1) 


SPECTRAVIDEO 




AUTO <nl>, <mc> 


RENUM <nue.> H <ant.>, 
<ínc> 


DELETE <inic>-<fin.> 


ZX-SPECTRÜM 


EDIT (2} 









<nl>: Número de línea. <inc>; Incremento. <nue >: Nuevo número de línea. <ant>: Número de línea antiguo. <inic.>: Número de línea inicial <fin.>: Número de línea 
r naL 



FORMULACIONES DE LOS COMANDOS 

EDIT <NL>: Edita Ja línea cuyo número se indica. AUTO <nl>, <inc>: Genera automáticamente (os sucesivos números de línea tras cada pulsación de la tecla RETURN. La 
- jmeración empieza a partir de <nl>, en sucesivos incrementos de <inc> unidades. RENUM <nue>, <ant>, <ina>: Renumera las lineas del programa a partir de la 
-dícada en <ant>, situándolas a partir de la línea <nue > en incrementos de <inc> unidades. DELETE <inic>-<fin >: Borra el bloque de líneas comprendidas entre las 
dos especificadas. 



OBSERVACIONES 
il} SINCLAIR QL 

EDIT <n|> [, <inc>]: Edita la línea <nl> y sucesivas en incrementos de <inc>. RENUM [<iníc> |TO <fin>;]][<nue>][, <inc>]: Renumera automáticamente desde la 
■nea <ínic> hasta ta <fin > í tomando como base de la nueva numeración la línea <nue.> en incrementos de <ino> unidades. DLINE <ínic> TO <fin,>: Borra el bloque 
líneas indicado. Pueden encadenarse expresiones de este tipo, separando por comas los rangos de líneas a borrar. 



l ZX-SPECTRUM 

E! comando EDIT no lleva asociado un número de línea No obstante, hay que situar un cursor que aparece en pantalla sobre la línea a editar. 
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DELETE 



fcjmma las líneas situadas entre las especificadas 

Formato: DELETE [<línea inicia!>]-[<!inea fina!>~\ 

Ejemplos: DELETE 100-225 
DELETE 100- 
DELETE -225 






mmmm m i tm 


\ 'O 


REM SOFT § 


| 20 


PAPER 10, F|Ék l 


\ 30 


BORDER V^lgf | 


\ uo 


CLS, PW^¡$%\ 



delete 




10 REM SOFT 
20 PAPER 1 




*J *¡| DELETE 

fo al 30 - 50 




- 


60 PRINT" SOFT'* 



El coma tuh DELETE 
permite borrar una línea 
o un grupo de lineas del 
programa ''de un 
plumazo**. Ei bloque de 
líneas a eliminar debe 
de finirse en el 
argumento de la referida 
instrucción. 



BORRADO DE LINEAS 



A ta hora de depurar un programa, tan 
importante es la posibilidad de intercalar 
nuevas líneas como la de borrar las anti- 
guas. Esta segunda alternativa se consi- 
gue por el simple procedimiento de te- 
clear el número correspondiente a la línea 
en cuestión, seguido por una acción sobre 
la tecla RETURN, Ello equivale a sustituir 
la línea especificada por una línea vacía de 
contenido. 

Este método resulta útil y rápido cuando la 
cantidad de líneas a borrar no es muy 
grande. Sin embargo, cuando se trata de 
borrar amplias zonas del programa, el tra- 
bajo puede llegara resultar agotador. Para 
este cometido existe un comando BASIC 
experto en el borrado de varias líneas a la 
vez: DELETE. Su formato como instruc- 
ción directa es el siguiente: 

DELETE <inicial>-<final> 

Los campos que siguen al comando de- 
terminan las líneas que deben desapare- 



cer del programa. El primer número espe- 
cífica el número de línea inicial o inferior 
del bfoque a eliminar y el segundo el nú- 
mero de línea final o mayor de los afecta- 
dos por el borrado. 

Partiendo del último listado remodelado 
por medio del comando RENUM, puede 
observarse el efecto de la omisión de uno 
de los campos en la instrucción DELETE, 

DELETE 30 

LIS 

10 REM COMANDO RENUM 

20 PRJNT "PROGRAMA EJEMPLO" 

40 INPUTA 

50 REM DETECCION DE FIN DE PROGRAMA 
60 IF A=Ü THEN GOTO 100 
70 LET B=A*A 

80 PRINT "EL CUADRADO DE";A 
90 PRJNT "ES:";B 
100 END 

Una de las posibles formulaciones parcia- 
les de la instrucción DELETE es la que 
incorpora un sólo número de línea en el 
argumento. Como revela el ejemplo ante- 
rior, su efecto se traduce exclusivamente 
en el borrado de la línea indicada. 
Otra de las posibles variantes de DELETE 
es la que muestra el siguiente ejemplo 



(DELETE 80-), La ausencia de número de 
línea final supone el borrado de todas las 
líneas del programa localizadas a partir de 
la inicial (línea 80 en el ejemplo): 

DELETE SO- 
LI ST 

10 REM COMANDO RENUM 

20 PRINT "PROGRAMA EJEMPLO" 

40 INPUTA 

50 REM DETECCION DE FIN DE PROGRAMA 
60 IF A-OTHEN GOTO 100 
70 LET B=A*A 

Una nueva ejecución de la instrucciónJJE- 
LETE, esta vez desprovista de número de 
línea inicial (DELETE -20), conduce al bo- 
rrado de las líneas que van desde el princi- 
pio del programa hasta la indicada (línea 
20): 

DELETE -20 
LIST 

40 INPUTA 

50 REM DETECCION DE FIN DE PROGRAMA 
60 IF A=0 THEN GOTO 100 
70 LET B=A*A 

Por último, ya sólo queda por observar la 
actuación de DELETE con su formato de 
instrucción más genérico: 



DELETE 50-60 



LIST 

W INPUT A 



70 LET B=A*A 
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Logo (5) 

Los procedimientos del LOGO 



la hora de definir las caracterís- 
ticas primordiales del LOGO, 
surge de inmediato el califica- 
tivo de lenguaje modular. En 
efecto, los programas en LOGO están 
construidos a base de módulos cuya con- 
junción da lugar a estructuras más com- 
plejas. Estos módulos son los denomina- 
dos procedimientos; una de las facetas 
Tiás importantes del LOGO, cuya defini- 
ción y empleo va a ser objeto de estudio 
en el presente capítulo, 



CREACION DE PROCEDIMIENTOS 



Jn procedimiento no es más que una su- 
;esión de órdenes encaminadas a realizar 
una acción más compleja. Requisito bá- 
sico es que el conjunto de órdenes que 
constituyen el procedimiento aparezcan 
rnjenadas en una secuencia apropiada; 
~ay que tener en cuenta que no es lo 
Tiismo sumar dos cantidades y elevar el 
resultado al cubo r que elevar al cubo las 
cantidades y luego sumar los resultados. 
_3S órdenes de un procedimiento, una 
r: ejecutadas, darán lugar a un resul- 
tado; éste coincidirá con la acción enco- 
mendada al procedimiento. Tal acción 
cede ser r sencillamente, una parte de un 
:5 culo más complejo. Por ejemplo, un 
■ : :edimiento que resuelva ecuaciones 
:t segundo grado resultaré de gran utili- 
dad a la hora de hallar solución a múltiples 
zrob lemas matemáticos. 
":oo procedimiento LOGO comienza con 
a palabra TO y finaliza con END. La pri- 



mera línea debe contener, tras la palabra 
clave TO, el nombre con el que se va a 
identificar al procedimiento. Ello índica al 
LOGO que a partir de ese punto empieza 
el procedimiento especificado. 
Las restantes líneas estarán ocupadas por 
las sucesivas órdenes, con una condición 
importante: la primera orden de cada línea 
debe ser un comando. En la última linea 
se colocará la palabra clave END, para que 
el LOGO entienda que ha concluido la de- 
finición de! procedimiento. 




El programa corresponde a la creación de 
un procedimiento. En efecto, cabe obser- 
var que se han respetado las condiciones 
impuestas para la definición. La primera 
línea empieza con la palabra TO r seguida 
por el nombre del procedimiento — HO- 
LA, en nuestro caso — , y la última línea 
incluye la orden END; esta última comu- 
nica al ordenador que ha terminado la de- 
finición. 

La respuesta de la máquina no se hace 
esperar; muestra en la pantalla el mensaje 
"HOLA DEFINED" (HOLA definido). 
A partir de este preciso instante, para ha- 
cer uso del procedimiento HOLA, bastará 
con teclear su nombre. 
Realmente, la creación de un procedi- 
miento equivale a definir una nueva orden 
en el vocabulario LOGO; una orden que 
funcionará exactamente igual que las in- 
cluidas en el repertorio original del LOGO. 
De hecho, un procedimiento puede in- 
cluso formar parte de otro procedimiento 
más complejo (su pe rproced i m ¡en to ) . Vea- 
mos un nuevo ejemplo: 



Los programas LOGO son 
estructuras n eudas a punir de 
la asociación de procedimientos o 
módulos elementales. Un 
procedimiento es un conjunto 
de órdenes destinadas a 
programar una determinada 



PROCEDIMIENTO 



TO NOMBRE 



ORDENES 



END 
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TO SALUDO 
HOLA 

PRINT [COMO TE LLAMAS?] 

PRÍNT LPUT FIRST RL [BUENOS DIAS] 

END 

SALUDO DEFINED 



En esta ocasión se ha definido un nuevo 
procedimiento, denominado SALUDO, Un 
dato significativo es que se ha utilizado el 
procedimiento anterior, HOLÁ H como si se 
tratara de un comando propio del LOGO. 
Esta filosofía permite la subdivisión de 
problemas complicados en pequeños 
fragmentos elementales. 
Por ejemplo, para calcular los gastos do- 
mésticos cabe seguir los siguientes 
pasos: 

— Apuntar gastos de alimentación. 

— Sumarlos y apuntar el resultado. 

— Apuntar gastos de servicios contrata- 
dos para la casa (luz, agua...}. 




Los procedimientos pueden asociarse para dar cuerpo a ' superprocedimientos o 
procedimientos LOGO más complejos* 



Sumar y escribir resultado. 
Apuntar gastos de otras compras. 
Sumar y apuntar resultado. 




La medularidad del lenguaje LOGO queda plasmada en los procedimientos. Estos son módulos 
que pueden integrarse sucesivamente en otros procedimientos, cada vez más complejos, hasta 
constituir el programa. 



— Sumar los totales y escribir el resul- 
tado. 

La tarea aparece fraccionada en un con- 
junto de acciones elementales que, sin 
lugar a dudas, facilitan la comprensión y el 
cálculo. Esta misma filosofía de descom- 
poner un trabajo en acciones parciales es 
compartida por la programación en LOGO. 
£1 caso propuesto puede adoptar la forma 
de procedimiento LOGO: 

TO GASTOS 
ENTRA.ALIMEN 
SUMA.AÜMEN 
ENTRACASA 
SUMA.CASA 
ENTRA OTROS 
SUMA. OTROS 
SUMATOTAL 
END 



El procedimiento global GASTOS incluye 
las sucesivas acciones a realizar para eva- 
luar el gasto doméstico total; desde 
luego, hace uso de otros procedimientos 
más elementales que será preciso definir 
por separado. En el ejemplo, se observa 
que todas las órdenes de GASTOS son 
procedimientos. Todas ellas deben ser 
creadas antes de utilizar el procedimiento 
GASTOS. 
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La definición del último de ellos, SUMA. 
TOTAL, puede adoptar la siguiente forma: 



TO SUMATQTAL 

MAKE TOTAL SÜM :0TR0S :CASA 
ALIMENTOS 

PRIMT [TOTAL GASTOS] 
PRINT LIST :T0TAL "PTS 
END 

SUMATOTAL DEFINES 



Las variables OTROS, CASA y ALIMEN- 
TOS, utilizadas para calcular la suma total, 
contienen las sumas parciales de los res- 
pectivos conceptos. Por ejemplo, la varia- 
ble :CASA que almacena el gasto total de 
ios servicios domésticos contratados se 
calculará dentro del procedimiento SU- 
MA. CASA; 

TO SUMA.CASA 

MAKE "CASA SUMLIST :LISTACASA 
PRINT [TOTAL GASTOS DE CASA] 
PRINT LISTXASA "PTS 
END 

3 procedimiento SUMA. CASA hace uso 
del subprocedimiento SUMLIST a modo 
de operador. SUMLIST admite una en- 
trada y proporciona una salida; este tipo 
de procedimientos, que pueden actuar in- 
distintamente como comandos u opera- 
dores, reciben el nombre de procedimien- 
tos con parámetros. 



PROCEDIMIENTOS 
CON PARAMETROS 



z 



Al igual que ocurre, en el caso general, 
con los datos del LOGO, cabe distinguir 
dos tipos de parámetros: de entrada y de 
salida. Los primeros constituyen datos de 
entrada al procedimiento y deben especi- 
arse detrás del propio nombre del pro- 
cedimiento. Por ejemplo: 
TO SUMLIST :L 

ndica que el procedimiento SUMLIST 
precisa de un dato de entrada represen- 



PARAMETRO 
DE 
ENTRADA 



PROCEDIMIENTO 



CON í 



PARAMETROS 



Los procedimientos pueden exigir te 
presencia de parámetros de entrada que 
precisen su actuación ai ejecutados. 
Asimismo, los procedimientos pueden emitir 
datos o parámetros de salida. 

tado por la variable :L. En el mismo caso, 
el dato en cuestión será identificado, den- 
tro del procedimiento, por :L 
El procedimiento SUMLIST podría defi- 
nirse de la siguiente forma: 

TO SUMLIST :L 

IF EMPTYP :L [OUTPUT 0 STOP] 
OUTPUT SUM (FIRST :L) [SUMLIST 
(BUTFIRST :L» 
END 

Este procedimiento es algo más compli- 
cado; si bien, por el momento sólo se 
prestará atención a los parámetros de en- 
trada y salida. 

El parámetro de entrada se ha utilizado 
como dato en los cálculos. Su empleo es 
idéntico ai de las variables; ello permite 
que el procedimiento admita distintos da- 
tos como entrada. 

Respecto a la salida, hay que mencionar al 
operador OUTPUT (salida). OUTPUT co- 
loca su dato de entrada como dato de 
salida del procedimiento en el que se en- 
cuentra. En el ejemplo propuesto, el men- 
cionado operador se utiliza para "extraer" 
el valor de la suma. Por supuesto, un de- 
terminado procedimiento puede carecer 
de uno o de ambos tipos de parámetros. 
A continuación aparecen dos ejemplos 
prácticos que ilustran la actuación del ope- 
rador OUTPUT y resumen el comporta- 
miento de un procedimiento con paráme- 
tros. 

El primero de ellos adjudica el dato numé- 
rico 3 al procedimiento TRES; una opera- 
ción análoga a las asignaciones de varia- 



PARAMETRO 
DE 
SALIDA 



bles, tal como se observa al ordenar la 
impresión de TRES: 



TO TRES 

0lfTPUT3 

END 

TRES DEFINED 

PRINT TRES 

3 




El segundo ejemplo, algo más evolucio- 
nado, ilustra la actuación de un procedi- 
miento con parámetros. En primer lugar, 
se procede a la definición del procedi- 
miento INICIAL, asociándole un paráme- 
tro; PALABRA y se define la función de 
imprimir el primer elemento del citado pa- 
rámetro. 



TO INICIAL : PALABRA 
PRINT FIRST i PALABRA 
END 

INICIAL DEFINED 
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TABLA DE ORDENES-LOGO 


INSTRUCCION 


COMETIDO 


OPERADOR/ 
COMANDO 


MAKE <palabra> <dato> 


Crea variable 


Comando 


TO <nombre> [<variab1es>] 


Crea procedimiento 


Comando 


END 


Determina el fin de un procedimiento 


Comando 


EDIT [<nombre>..J 


Activa el editor de procedimientos 


Comando 



<nombre>: nombre del procedimiento (sin comillas). 
<variables>: posibles variables locales {precedidas por dos puntos). 





EDICION DE 
PROCEDIMIENTOS 




J v_ 




A la hora de modificar un procedimiento, no es preciso re escribí rio de nuevo en xa integridad. 
El lenguaje LOGO dispone de un comando de edición (FDFT) que visualiza el contenido del 
procedimiento elegido y permite su modificación. 



Una vez definido el procedimiento pode- 
mos ya utilizarlo en la práctica, sin más 
que recurrir a su nombre como si se tra- 
tara de una orden LOGO. 




En el primer caso, se le otorga como dato 
de entrada la palabra DAVID, Su ejecución 
mostrará en pantalla el primer elemento 
(letra D) del dato entregado como pará- 
metro. 

La entrada asociada al procedimiento con 



parámetro INICIAL puede ser también una 
variable. La asignación MAKE, otorga la 
palabra PACO a la variable JEFE. Ahora, al 
ejecutar el procedimiento INICIAL sobre 
el parámetro JEFE, la pantalla mostrará la 



primera letra del nombre PACO contenido 
en la variable JEFE. 



EDICION DE PROCEDIMIENTOS 



Si se desea modificar un procedimiento 
no hace falta escribirlo de nuevo. El co- 
mando EDIT facilita esta tarea, visuali- 
zando y permitiendo la modificación de 
procedimientos. EDIT admite un dato de 
entrada que puede coincidir con un nom- 
bre de procedimiento (palabra) o con va- 
rios nombres (lista). 

Realmente, EDIT abre el acceso al editor 
de procedimientos. Una vez en el editor, 
se visualiza el procedimiento o procedi- 
mientos especificados y el cursor. Este 
último puede posícionarse allí donde el 
usuario desee realizar el cambio. 
Es posible editar más de un procedi- 
miento a la vez. Para ello es preciso con- 
feccionar una lista con los nombres de los 
procedimientos y situarla como dato de 
entrada al comando EDIT. Por ejemplo: 

EDIT 'TRES 

EDIT [GASTOS SUMATOTAL SUMA,CASA 
SUMLIST] 

son formulaciones correctas del mencio- 
nado comando. En el primer caso facilitará 
la modificación del procedimiento cuyo 
nombre es TRES, mientras que en el se- 
gundo permitirá la edición de los cuatro 
procedimientos cuyos nombres figuran 
en la lista. 




La orden EDIT 
vuelca el 
procedimiento en 
la pantalla y 
brinda id usuario 
la posibilidad de 
corregir y alterar 
su contenido. La 
edición se reduce 
a desplazar el 
cursor al punto 
adecuado y 
utilizar las teclas 
alfabéticas y 
numéricas para 
realizar los 
cambios 
oportunos. 
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Los ficheros del CP/M 

Manejo de la información 
en la memoria externa 



I sistema operativo CP/M frac- 
ciona las tareas cuya respon- 
sabilidad tiene encomendada 
en tres grandes bloques. Es- 
tos guardan una perfecta consonancia con 
la estructura modular del CP/M, de tal 
forma que cada bloque de tareas es ges- 
tionado por uno de los tres módulos cons- 
titutivos: CCP (procesador de comandos 
de consola), BDOS (sistema operativo bá- 
sico de disco) y BIOS (sistema básico de 
entrada/salida), 



GESTION DE INFORMACION 
EN LA MEMORIA EXTERNA 



_a misión del BDOS es ofrecer al usuario 
tos medios adecuados para un manejo 
simple y eficaz de la información almace- 
nada en ios discos del sistema. Para ello, 
nrinda un determinado número de funcio- 
nes, previamente programadas en el sis- 
:ema operativo, que permiten la manipu- 
ación de ficheros y registros, y liberan al 
usuario de la preocupación de generar el 
espacio requerido para el almacenamiento 
□e ficheros en el disco. 
- diferencia con el CCP, el módulo BDOS 
no está abierto a un acceso directo a base 
ce comandos introducidos a través del te- 
clado; su acceso es más arduo, puesto 
que hay que descender hasta el nivel del 
enguaje ensamblador. 
En todo caso, el propio sistema operativo 
apoya esta actividad. La ejecución de las 
funciones del BDOS se ve facilitada por la 
existencia de ciertas rutinas dentro del 
5 stema operativo. Estas trasladan a un 
registro de almacenamiento interno del 
~ croprocesador un indicativo de la fun- 
i'ón que se desea realizar y apelan a la 
¿ztívidad del BDOS; de inmediato, éste 



ejecutará la tarea precisada por el código 
de función y, acto seguido, zs.z .e-a e 
control al programa desde el cual fue fe- 
mado. 

Los ficheros que crea y con los que opera 
el sistema operativo CP/M, están consti- 
tuidos por una colección de registros de 
128 bytes cada uno. Cada fichero puede 
incorporar un máximo de 65.536 regis- 
tros; ello significa que el tamaño máximo 
de un fichero CP/M es de 128 x 65.536 - 
8.378.508 bytes, o lo que es to mismo 8 
Megabytes. 

Las operaciones de lectura y escritura no 
se efectúan adoptando como patrón el 
registro, sino que se realizan a un nivel de 
los denominados bloques. Un bloque 
equivale a un conjunto de registros cuyo 
número es variable, dependiendo de 
cómo se ha definido la tabla de paráme- 
tros del disco. Por lo tanto, con una opera- 
ción física de lectura se consigue leer ef 
contenido de varios registros a la vez. Esta 
característica redunda en beneficio de la 
velocidad de acceso a disco, ya que los 
mecanismos de lectura son bastante len- 
tos en comparación con otros componen- 
tes del sistema. 




La misión del módulo 8 DOS es ofrecer al 
usuario los medios adecuados para un 
manejo cómodo y eficaz de la información 
almacenada en los discos. 



Al igual que ocurre con los registros, los 
bloques son también agrupables en con- 
juntos que reciben el nombre de extensio- 
nes. El tamaño de cada extensión es tam- 
bién variable: de 1 a 16 k. 
Los dos métodos de acceso a disco más 
frecuentes en el CP/M son los denomina- 
dos de acceso secuencia l y de acceso 
directo. 

En ei primero es obligatorio ir leyendo los 
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registros, uno tras de otro, en el orden 
estricto en el que están colocados en el 
fichero. Ello signrñca que para leer un de- 
terminado registro del fichero, será nece- 
sario leer previamente todos los que le 
preceden. 

El acceso directo obvia esta dificultad, 
puesto que permite acceder a cualquier 
registro sin tener que pasar necesaria- 
mente por los anteriores; desde luego, 
hay que saber cuáf es la posición que 
ocupa el registro en cuestión. 
La información completa de un fichero 
está almacenada en una sección de la me- 
moria que el CP/M reserva para este co- 
metido, Esta zona, denominada bloque de 
control de fichero (del inglés "File Control 
Block"} dedica un espacio de 33 bytes de 
longitud para los ficheros de acceso se- 
cuencial y de 36 para los de acceso di- 
recto. Cada uno de estos espacios o blo- 
ques de control, memorizan el número de 
disco en el que está el fichero, su nombre 
y tipo, la extensión que ocupa, la posición 
actual para leer y escribir, información 
acerca del emplazamiento de Jos registros 
en el fichero... 

De igual forma que se tiene una informa- 
ción completa acerca de cada fichero, 
también se dispone de la misma informa- 
ción a nivel disco; el BDOS genera un 
catálogo o directorio con fa información de 
todos los ficheros residentes en el disco 
sobre el que se está operando, hasta un 
máximo de 128, 

Cada entrada del catálogo ocupa 32 by- 
tes: los 16 primeros constituyen un re- 
flejo de los 16 bytes iniciales del FCB, tal y 
como quedarán al cerrar el fichero; a su 
vez, los 16 últimos bytes representan el 
mapa de ocupación de espacio en disco 
por parte del fichero. 



ORDENES DIRECTAS A LOS 
DISPOSITIVOS FISICOS 



El módulo BIOS incorpora toda una serie 
de funciones de bajo nivel necesarias para 
la interacción de los programas del CP A/1 
y BDOS con el soporte físico de la má- 
quina. Estos indican cómo hay que acce- 
der a los distintos dispositivos que confor- 
man el sistema; por ejemplo, gestionan el 
desplazamiento de la cabeza del disco 



para que se mueva a través de su super- 
ficie. 

El BIOS contiene, en definitiva, los progra- 
mas de entrada/salida específicos para la 
configuración hardware adoptada. Gene- 
ralmente estos programas son confeccio- 
nados por el fabricante del microprocesa- 
dor; su diseño es muy crítico, debido a 
que cualquier ligero error hará que no fun- 
cione el sistema o que lo haga inadecua- 
damente. 

Si se desea tener aceso a periféricos de 
tipo no estándar, es preciso modificar 
consecuentemente el programa o progra- 
mas al efecto del módulo BIOS, 



REFERENCIAS A UN FICHERO 
EN CP/M 



instante. Habitual mente, es posible refe- 
rencia r hasta un máximo de 16 discos. 

Nombre del fichero 
El nombre del fichero ha de contener un 
máximo de ocho caracteres aifanumérí- 
cos. Al efecto suelen utilizarse las letras 
mayúsculas; no obstante, en ciertos ca- 
sos especiales es posible definir ficheros 
con letras minúsculas, e incluso sin nom- 
bre. Hay ciertas restricciones en las com- 



La identificación de un fichero en el sis- 
tema operativo CP/M consta de una refe- 
rencia al disco en el que reside, del nom- 
bre de dicho fichero y el tipo que le haya 
sido asignado. En definitiva, el formato 
general es: 

disco: nombre.tipo 

Disco 

Los discos son referen ciad os por una letra 
que los identifica e indica al usuario cuál 
de ellos es accedido en un determinado 




Cada archivo en disco consta de una 
es trac tura en la que caben varios ni vetes. En 
fa base están los registros, cuya asociación 
constituye un bloque, A su vez, la agrupación 
de varios bloques da cuerpo a las 
extensiones. Varias extensiones constituirán, 
en definitiva, ei fichero en disco. 



/ REG.N 128 bytes 



REG2 128 bytes 



REGJ 128 bytes 



BLOQUE 1 (1.2A8Ó16K) 



/ REG.N 128 bytes 



REG.2 128 bytes 



REG1 128 bytes 



BLOQUE N (1 ( 2¿,8ól6K) 




Al igual que los registros se agrupan para conformar los denominados bloques, también estos 
últimos son asociables. dando lugar a las "extensiones" . El tamaño de cada extensión puede 
estar comprendido entre I y 16 K. 
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binacíones de caracteres capaces de ge- 
nerar el nombre de un fichero; determina- 
dos signos son inadmisibles y su empleo 
conduce a error Los símbolos no utiliza- 
bles en la combinación de un nombre de 
fichero coinciden con los que se indican a 
continuación: 

<>[]()*?/; 

La incorrección de los dos últimos carac- 
teres es obvia: de utilizarlos confundirían 



al CCP, puesto que dicho módulo los re- 
conoce como separadores. De igual 
forma, tampoco son válidos todos los ca- 
racteres de control definidos por la com- 
binación de la tecla CONTROL y otro ca- 
rácter, además de aquellos caracteres que 
no tengan representación en la pantalla. A 
continuación se relacionan varios nom- 
bres de ficheros correctos e incorrectos; 



Trabajo 1 ; 



NOTA' 



135910: 

ESPECIFICACION: 
DATO<CTRL-U>: 



NOMBRE: 



Correcto. 



Correcto sólo en al- 
gunos casos (utiliza 
minúsculas). 
Incorrecto por con- 
tener un carácter no 
autorizado. 
Correcto. 
Erróneo por tener 
más de 8 caracteres. 
Erróneo por incluir 
caracteres de control. 



Manipulación y traslado de ficheros 



Dentro del módulo CCP, existe un 
comando íran si torio que permite el 
intercambio de información entre diversos 
periféricos del sistema. Dicho comando 
responde at nombre de programa de 
intercambio entre periféricos o PIP (del 
inglés: "Perípheral interchange program"). 
Las capacidades del PIP permiten copiar 
ficheros de un disco a otro o en el mismo 
disco, concatenar o unir varios ficheros 
distintos en un fichero único, convertir 
letras de mayúsculas a minúsculas al 
mismo tiempo que realiza la 
operación de copia... 
El formato adecuado para la ejecución de 
este comando no es único, sino que 
admite dos variantes. En la primera de 
ellas, la línea de comando consta 
exclusivamente del comando en sí (PIP), 
Al procesarlo, la máquina pasa a 
instaurarse en un modo de trabajo o 
entorno de ejecución propio del comando 
(PIP); éste se caracteriza por la aparición 
en la pantalla de un indicador de petición, 
representado por un asterisco { *). En 
estas condiciones, el ordenador queda a 
la espera de recibir las acciones que el 
usuario desee llevar a cabo. Por supuesto, 
todas las operaciones que se ordenen 



deben ser de manipulación y traslado de 
ficheros; operaciones admisibles por el 
comando PIP. Tras introducir las 
operaciones pertinentes, debe cerrarse eí 
comando PIP con una simple acción sobre 
la tecla de retomo Í<CR>). 
Un ejemplo ilustrativo del comando P1P r 
en el formato indicado, es el que refleja -la 
siguiente pantalla; 



A> PIP 

* B:DAT0ASM- 

* B:HUEV0/TCX= 

* <CR> 
A > 




DAT0.A5M 

=B:V1EJ0.Tra 



En él se ordena la realización de dos 
copias; una del fichero DATO ASM del 
disco A al fichero DATO ASM del disco B, 
y la otra del fichero VIEJO.TEX, ambos 
contenidos en el disco B. Como se 
observa, el cierre del comando se realiza 




con una acción sobre la tecla RETURN 
(retroceso del carro); el ordenador 
responde retornando a modo normal 
El segundo formato o modo de empleo 
de! comando, es el de uso más frecuente. 
Una sola línea de comando incluye la 
orden PIP y define los ficheros implicados 
en la operación. Una vez ejecutada la línea 
en cuestión, el monitor vuelve a retomar 
el control de la máquina, A título de 
ejemplo, la orden siguiente realiza una 
copia múltiple con un sólo comando PIP; 



A>PIPTODO.BAS: 
BAS.BAS3.BAS 



-BAS1.BAS,BAS2. 



Exactamente, ordena la copia de los 
ficheros BASLBAS,BAS2.BAS y 
BA53.BAS,uno a continuación de otro, en 
un único fichero denominado TODO.BAS. 
A raíz de los ejemplos precedentes se 
observa que el formato general bajo el 
que actúa el comando PIP adopta la 
siguiente forma; 

fichero de destino = fichero fuente 1, 
fichero fuente 2... (opciones) 

El fichero de destino designa al fichero o 
periférico que debe recibir los datos; por 
su parte, la zona de fichero fuente define 
al fichero o ficheros que deben ser 
copiados en el de destino. A continuación, 
puede incluirse una zona de opciones, 
cuya misión es la de matizar las 
transferencias ordenadas. 
Las diversas opciones disponibles 
permiten, entre otras cosas; 

— Truncar o cortar un fichero a partir de 
un número de columna n r 

— Tratar sólo ficheros que hayan sido 
modificados después de una fecha límite. 

— Parar o comenzar la copia a partir del 
punto en el que se encuentren ciertas 
letras claves. 

— Comprobar que la transacción se ha 
realizado correctamente. 
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s.o. 





ARCHIVO 



1 



PARCHIS 




REFERENCIA 
DEL 
DISCO 



NOMBRE 

DEL 
FICHERO 



TIPO 
DE 
FICHERO 



La identificación de an fichero consta de tas tres zonas que refleja ia ilustración: una 

re ferencia al disco en el que reside, el nombre otorgado ai fichero y una tercera etiqueta que 

indica el tipo de fichero. 



Como norma general, es conveniente uti- 
lizar nombres de ficheros que sean signifi- 
cativos, de tal forma que constituyan un 
reflejo de su contenido y ayuden al usua- 
rio a su rápida identificación. 

Tipo de fichero 

Los diversos tipos de ficheros aluden a la 
función o al contenido de ios mismos. La 
referencia al tipo, situada a continuación 
del nombre del fichero, consta de un má- 
ximo de tres caracteres; a su vez, es ob- 
jeto de fas mismas restricciones en su 



formación que las descritas anteriormente 
para los nombres de fichero. 
El sistema reconoce varios tipos de fiche- 
ros estándar, lo cual no es óbice para que 
el usuario pueda crear tipos propios. Por 
ejemplo, en las diversas etapas del desa- 
rrollo de un programa se pueden utilizar 
tipos no estándar que indiquen cuál es el 
estado intermedio del programa; al con- 
cluir el desarrollo, puede ya referen ciarse 
el fichero con el tipo que le sea propio. En 
la mayor parte de los casos no es necesa- 
rio indicar el tipo de los ficheros, a no ser 



b: * .obj 





1 


1 CAJA 1 




MAILING 1 




SUELDO t 




OBJ 


OBJ 


OBJ 


1 





b: * .BAS 







1 PAGOS | 




NOMINAS! ' 




CARTAS 1 




BAS 

1 H 


BAS 


BAS 







que el comando que le afecte exija esta 
condición. 

Entre los múltiples tipos de ficheros es- 
tándar aceptados por el CP/M, están, por 
ejemplo, ¡os siguientes: 

COM; Comando ejecutable. 

ASM: Programa fuente en lenguaje en- 
samblador. 

BAS: Programa fuente en BASIC. 

$$$: Fichero temporal del editor. 

OBJ: Programa objeto resultado de un 
proceso de compilación, 

A veces, es posible que no se conozca 
con exactitud el nombre del fichero que 
se desea utilizar; o también puede darse 
el caso que se pretenda utilizar más de un 
fichero simultáneamente. Para resolver 
ambas situaciones, el sistema operativo 
permite unos formatos especiales llama- 
dos referencias ambiguas o "wildcards" 
que son capaces de generalizar el signifi- 
cado del comando. 
Cuando se utiliza el asterisco {*) éste sus- 
tituye al nombre y/o tipo del fichero de 
forma completa. A su vez, el signo de 
interrogación (?) puede reemplazar a uno 
de los caracteres del nombre o tipo de 
fichero. Los siguientes ejemplos ilustran 
el empleo de las referencias ambiguas. 

*.FOR: Se refiere a todos los fiche- 
ros FORTRAN. 

NUEVO.*: Alude a todos los ficheros de 
cualquier tipo, cuyo nombre 
es NUEVO. 

\ *': Referencia a todos los fiche- 

ros. 

???1,FOR: Se refiere a todos ios fiche- 
ros cuyo nombre posea cua- 
tro caracteres, siendo el úl- 
timo de ellos el número 1 r y 
cuyo tipo sea FORTRAN. 




El st si ef na operativo CPfM admite el aso de referencias ambiguas {wildcards J en la definición de los ficheros. Por ejemplo, el asterisco (*) es el 
signo adecuado para generalizar los campos de nombre y tipo del fichero. En el gráfico, el asterisco se utiliza para refere ndar 
a todos los ficheros de tipo OBJ resistentes en el disco B (izquierda ¡, a todos los de tipo BAS residentes en el mismo disco (centro) y a los 
ficheros de cualquier tipo, contenidos en el disco B, cuyo nombre es caja (derecha). 
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Wordstar (I) 

Una aplicación estandarizada 
para el tratamiento de textos 



n el presente capítulo se abre 
el estudio de las principales 
aplicaciones creadas para el 
proceso de textos en ordena- 
dores personales. EJ primero de los pa- 
quetes, cuyo análisis práctico ocupará los 
tres próximos capítulos de la obra, es el 
WORDSTAR; sin duda alguna, el trata- 
miento de textos más extendido y popular 
en Ja categoría de equipos. Más adelante, 
se acometerá el estudio de las aplicacio- 
nes de proceso de textos predominantes 
en el marco del ordenador personal. 



¿QUE ES EL WORDSTAR? 



Micropro International Corporation es la 
firma americana creadora de este paquete 
para el tratamiento de textos destinado al 
ámbito de los ordenadores personales. En 
la actualidad existen versiones de 
WORDSTAR creadas para su compatibili- 
dad con distintos sistemas operativos; no 
obstante, la versión inicial y más difundida 
se desarrolló para trabajar bajo el control 
del sistema operativo CP/M, 
Resulta difícil definir en una única frase 
qué es el WORDSTAR. En una breve sín- 
tesis cabe catalogarlo como "una aplica- 
ción interactiva dedicada al proceso de pa- 
labras con objeto de producir un docu- 
mento escrito". 

Su funcionamiento exige una configura- 
ción en la que el ordenador personal esté 
complementado con algunos periféricos 
básicos: pantalla, teclado, una unidad para 
discos flexibles y una impresora. 
El proceso típico permite introducir un 
texto original a través del teclado. Este se 
almacenará en un disco flexible para, pos- 
teriormente, visualizarlo y/o modificarlo 



sobre la pantalla, antes de imprimirlo con 
un determinado formato. En todo caso, 
ios archivos que puede tratar no tienen 
por qué ser cargados de forma manual; 
otras aplicaciones, independientes del 
WORDSTAR aunque capaces de crear ar- 
chivos compatibles, pueden generar el ar- 
chivo en disco. Posteriormente, podrá uti- 
lizarse dicho archivo para realizar un trata- 
miento de textos sobre su contenido (mo- 
dificar el formato de salida, variar el conte- 
nido, obtener copias nominales..! 



PRINCIPALES COMANDOS 
DEL WORDSTAR 



1. COMANDOS BASICOS DE 
EDICION EN PANTALLA 

La misión encomendada a los comandos 
de edición, tanto en este procesador de 




PROGRAMA TEXTOS 



WORDSTAR es uno de los paquetes estandarizados para el tratamiento de textos de mayor 
difusión en el ámbito de ios ordenadores personales. Su autoría corresponde a la firma 
americana Micropro ínternational. 
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La configuración básica, necesaria para la 
explotación del ira f amiento de textos 
WORDSTAR, exige la presencia de ios 
periféricos básicos que completen la 
funcionalidad del ordenador personal. 






// 




1 m 


3 IMPRESORA " 1 





UNIDAD CENTRAL l 






UN' DAD: DE DISCOS 




A n H 




WORDSTAR d 



o 
l 



TECLADO 



textos como en todos los que se analiza- 
rán en otros capítulos de la obra H es la 
creación y modificación de documentos 
almacenados en un dispositivo de memo- 
ria auxiliar, habitualmente en disco flexible 
o rígido. Algunas de las principales opera- 
ciones realizables mediante los comandos 
de edición son: creación de ventanas de 
edición, de tal forma que en una misma 
pantalla física se puedan editar simultá- 
neamente varios documentos, forma- 
teado de textos en la pantalla, solicitud de 
ayuda para la inclusión de guiones... 
Al utilizar el editor de pantalla, ésta pre- 
sentará siempre una parte del documento 
que se está introduciendo o modificando 
en ese preciso instante. Cualquier actuali- 
zación que se realice en el texto, se refle- 
jará de forma instantánea en la pantalla; 
para ello, es preciso posicionar el cursor 
(posición activa de la pantalla) en el lugar 
deseado antes de escribir. 
En el teclado se encuentran grupos varios 
de teclas fundamentales para el trabajo 
con el WORDSTAR. 

En el apartado de edición, cabe destacar a 
un primer grupo de teclas, marcadas nor- 
malmente con una flecha hacia arriba, 
abajo, derecha o izquierda, cuya función 
es la de mover el cursor sobre la pantalla 
sin modificar los caracteres sobre los que 
se desplaza. Por supuesto, el otro grupo 
básico de teclas son las que constituyen 
el teclado alfa numérico; zona coincidente 
con el teclado de una máquina de escribir 



convencional. En él se encuentran las te- 
clas alfabéticas, numéricas, el espaciador 
y algunos símbolos y caracteres especia- 
les. Cuando se pulsa alguna de ellas, el 
carácter correspondiente aparece sobre el 
cursor; éste se desplaza hacia su derecha 
para permitir la introducción de un nuevo 
carácter. 

En definitiva, el teclado alfanumérico 
constituye la vía para la introducción del 
texto; una tarea que se verá apoyada y 
facilitada por las funciones del editor. El 
propio editor permite comprobar el as- 
pecto final del texto, de forma que el 
usuario pueda corregirlo, en el caso de 
cometer un error o por un simple cambio 
de criterio, antes de plasmarlo en el papeL 
Las modificaciones que la aplicación rea- 
liza automáticamente sobre el texto intro- 
ducido son las siguientes: 

— Fin de línea automático 
Inicialmente, los párrafos se escriben sin 
accionar la tecla RETURN, esto es, sin que 
el usuario se preocupe de cómo termina 
cada línea de texto. Cuando una palabra 
rebasa el margen derecho, el WORD- 
STAR la traslada sistemáticamente a la 
línea siguiente, inserta blancos para ali- 
near el párrafo y muestra en la pantalla e! 
resultado final. Por lo tanto, la tecla RE- 
TURN tan sólo se utilizará para señalar un 
fin de párrafo. De esta forma, el operador 
de WORDSTAR queda liberado de la ac- 
ción de delimitar los finales de línea y, por 



lo tanto, no necesita levantar la vista de! 
original que esté mecanografiando. 

— Gestión del texto 
Al utilizar la opción fin de línea automático, 
cada vez que se escriba una línea ésta 
quedará justificada entre los márgenes iz- 
quierdo y derecho. Desde luego, el usua- 
rio puede ordenar un ajuste distinto; en tal 
caso puede optar por otras alternativas 
que ofrece la aplicación: margen derecho 
irregular, escritura a doble o triple espacio, 
o centrado entre márgenes derecho e iz- 
quierdo distintos a los existentes. 

— Reforma de párrafos 

Para modificar cualquier párrafo del docu- 
mento, el WORDSTAR ofrece un nutrido 
repertorio de comandos; comandos que 
permiten cambiar los márgenes, la sepa- 
ración entre líneas, pasar de margen dere- 
cho alineado a margen derecho irregular 
(o viceversa) o eliminar a voluntad caracte- 
res, palabras o líneas del párrafo en curso 
de modificación. 



2. COMANDOS ESPECIALES DE 
EDICION EN PANTALLA 

Además de los comandos básicos de edi- 
ción, apuntados en el apartado prece- 
dente, el WORDSTAR dispone de coman- 
dos especíales para ordenar diversas fun- 
c i o nes , por eje m pío ; 
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— Colocar o quitar tabuladoras para el 
texto. 

— Copiar, borrar o mover bloques com- 
pletos del texto. 

— Colocar o buscar marcas dentro del 
texto. 

— Buscar porciones del texto. 

— Buscar y modificar porciones del 
texto. 

— Insertar dentro de un documento el 
texto de otro documento archivado en la 
memoria de masa. 

También dispone de un sistema de ayuda 
para la colocación de guiones en palabras 
cortadas. De hecho, el WORDSTAR de- 
termina automáticamente los lugares ade- 
cuados para dividir una palabra entre lí- 
neas, utilizando un guión. Por supuesto, el 



La edición de texto empieza con ia escritura 
del mismo en la pantalla , utilizando id efecto 
el teclado incorporado ai ordenador. Para 
Situar el panto de escritura en cualquier zona 
de la pantalla, el usuario cuenta con cuatro 
teclas cuya misión es desplazar el cursor en 
ios cuatro posibles sentidos (hacia arriba T 
abajo, izquierda y derecha)* 



operador puede decidir Ea oportunidad de 
colocar o suprimir la presencia del guión. 
Los guiones insertados por el programa 
tienen carácter temporal ya que si se rea- 
liza una reforma posterior del texto, eJ 
guión podría quedar ubicado en mitad de 
la línea; de ahí que su escritura quede 
condicionada a cada situación momentá- 
nea. 





Elementos software para el proceso de textos 



Al hablar de los elementos hardware 
necesarios para el proceso de textos, 
citábamos en primer lugar al propio 
ordenador; más exactamente, a la unidad 
central de la máquina en la que se realiza 
el tratamiento de textos. Tal decisión 
queda justificada por el hecho de que el 
resto de los componentes físicos son 
incapaces de funcionar sin la intervención 
del procesador. Pues bien, el propio 
procesador (elemento físico, al fin y al 
cabo) es incapaz de realizar ningún tipo de 
tarea sin la intervención de programas 
que lo instruyan correctamente. En 
síntesis, eí software imprescindible para 
el funcionamiento de un sistema para el 
tratamiento de textos consta de dos tipos 
de programas. 

• El sistema operativo 

Asi se denomina al conjunto de 
programas que permiten el 
funcionamiento general del ordenador; 
tanto para su empleo como sistema 
dedicado al tratamiento de textos, como 
para su aplicación en cualquier otro tipo 
de actividad 

• Paquete de programas para el 
tratamiento de textos 

Se encarga de instruir a la máquina para 
que ésta brinde al usuario todo un abanico 
de facilidades que permitan realizar 
distintas operaciones sobre el texto inicial 
Su misión puede sintetizarse afirmando 
que admite como entrada de información 
un texto escrito, sin preocupaciones 
estéticas, y produce como salida el 
mismo texto pero con una presentación 



impecable, definida por eí usuario. 
Los paquetes de aplicación para eJ 
tratamiento de textos son, habitúa* mente, 
modulares, incluyen un conjunto de 
programas especializados e~ s zí z r. z" z~ 
las cistintas opciones ce se 2 
usuario, El conjunto de todos estos 



pfogramas está gestionado por otro 
programa denominado principal; éste 
suele presentar un menú de opciones 
que, se fecdonadas por el operario, dan 
paso a la ejecución de los adecuados 
programas especializados en las 
distintas funciones. 
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c 



TEXTO ORIGINAL 



TEXTO PARA BUSCAR 
j\ PALABRA VARCO 
Y MODIFICARLA POR 
BARCO 



SUSTITUCtON 



TEXTO PARA BUSCAR 
LA PALABRA BARCO ■ 
Y MODIFICARLA POR 
BARCO 



BUSCAR: VARCO 



TEXTO PARA BUSCAR 
LA PALABRA ■ VARCO 
Y MODIFICARLA POR 
BARCO 



TEXTO FINAL 



TEXTO PARA BUSCAR 
LA PALABRA BARCO 
Y MODIFICARLA POR 
BARCO 



Los comandos especiales de edición, permiten introducir el texto original con comodidad y 
rapidez, A título de ejemplo, la figura muestra una secuencia de "búsqueda y modificación 
de palabra, asociada a uno de los comandos especiales disponibles en el WORDSTAR, 



3. COMANDOS DE IMPRESION 

Este grupo de comandos del WORDSTAR 
facilitan la impresión de documentos ya 
escritos y almacenados con la ayuda de 
los comandos de edición. 
La elección del formato de impresión so- 
bre ef papel es el cometido básico de este 
grupo de comandos. Las principales ca- 
racterísticas de formato selecciona bles a 
la hora de imprimir un documento son las 
que se relacionan a continuación: 

— Forma teo de página 
En el margen superior de cada página del 
documento y/o en el margen inferior pue- 
den incluirse de forma automática "cabe- 
ceras" o "pies" de página, sin que el 
usuario deba introducir su contenido más 
que una vez. 

Para determinar el tamaño de la página y 
ios márgenes se utilizan los denominados 
' comandos punto". Si el operador no uti- 
liza estos comandos, el WORDSTAR to- 
mará valores por defecto. 



— Numeración de páginas 

El número de cada página puede escri- 
birse en el pie de página, centrado a la 
derecha o a la izquierda. No obstante, si el 
usuario lo desea, también podrá situarse 
en la parte superior de cada página. La 
numeración puede realizarla el programa 
automáticamente, si bien, el usuario 
siempre puede optar por modificarla o in- 
cluso omitir su presencia. 

— Control del salto de página 

Los cambios de página se realizan a me- 
dida que éstas se completan En todo 
caso, el salto de página también puede 
realizarse en cualquier situación, activado 
por los comandos de fin de página. Estos 
comandos pueden ser incondicionales o 
condicionales; los primeros provocan el 
cambio de página sea cual fuere la cir- 
cunstancia, mientras que los segundos 
sólo ejecutan el salto de página si se cum- 
ple una determinada condición (general- 
mente, se utilizan para asegurar la escri- 
tura de un mínimo grupo de lineas dentro 
de la misma página). 



— Efectos especiales 
El WORDSTAR está preparado para impri- 
mir textos con palabras subrayadas, en 
negrita, cursiva, etc. Para ello es necesa- 
rio utilizar un carácter especial prece- 
diendo a la palabra afectada; este carácter 
será quien active automáticamente el es- 
tilo de la presentación. 

Además de los ya citados, los efectos es- 
pecíales más interesantes son: subíndi- 
ces, superíndíces, espaciado proporcional 
entre los caracteres de una palabra y se- 
paración variable entre líneas. 
También es posible combinar los efectos 
especiales, Por ejemplo, se puede escribir 
una misma palabra subrayada, en negrita 
y como subíndice; 

— Justificación del texto 
con micro-espacios 

Para lograr una mejor distribución de los 
caracteres, el espacio en blanco entre pa- 
labras se distribuye de tal forma que la 
separación entre las distintas palabras de 
una línea y la separación entre los distin- 
tos caracteres de una palabra ofrezca un 
aspecto agradable. Si se utiliza una impre- 
sora de calidad estos ajustes se realizarán 
mediante micro-espacios. Sin embargo, 
cuando Ja impresora utilizada no permite 
el empleo de micro-espacios, el ajuste se 
realizará en base a espacios completos. 



4, COMANDOS DE OPERADOR 

Para concluir con la presentación de los 
distintos grupos de comandos del 
WORDSTAR, cabe mencionar a los co- 
mandos destinados a activar las funciones 
de impresión: 

— Comienzo o final de numeración. 

El usuario puede seleccionar la numera- 
ción de las páginas ya sea prefijando el 
número de la primera o de la última página 
de texto. La propia aplicación se encargará 
de otorgar a cada página el número ade- 
cuado, dependiendo de la condición ex- 
presada por el operador. 

— Utilización de caracteres para salto de 
página, 

— Detención entre páginas, para colocar 
hojas sueltas en la impresora, en el caso 
de no utilizar papel continuo, 

— Impresión del contenido de un archivo 
sin formato de página (impresión del texto 
tal y como se introdujo en el equipo). 

— Impresión o almacenamiento del do- 
cumento en un archivo en lugar de reali- 
zarlo a través de la impresora. 
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Operadores de relación 

Comparando datos. 

Los comandos NEW, STOP y CONT 



n el capítulo precedente se in- 
trodujo el concepto de ruptura 
de la secuencia de ejecución 
de un programa. En efecto, tal 
ruptura se traducía en un salto o bifurca- 
ción dentro del programa; éste podía ser 
incondicional o condicional Esta última 
posibilidad, sintetizada en las instruccio- 
nes de tipo IF/THEN/ELSE, suponía la en- 
trada en escena de una condición cuyo 
cumplimiento desviaba la secuencia de 
ejecución hacia otra zona del programa en 
curso 

Cabe recordar que la instrucción IF/THEN/ 
ELSE consta de tres zonas bien diferen- 
ciadas: la condición a chequear localizada 
tras la palabra clave IF r la instrucción o 
instrucciones a ejecutar si se cumple di- 
cha condición {zona THEN], y la instruc- 
ción o instrucciones a ejecutar en caso 
contrario (zona ELSE). 
No cabe duda que la parte principal de la 
instrucción la constituye la condición im- 
puesta, puesto que de su cumplimiento 
depende que se realice una u otra acción. 
Esta condición será, en general, una ex- 



presión que una vez evaluada producirá un 
resultado del tipo cierto o falso. Por ejem- 
plo, en el caso que sigue: 

IF A=0 THEN PRINT "A VALE CERO" 

la acción indicada por ei comando PRINT 
se ejecuta si es cierto que la variable A 
toma el valor cero. El ordenador, interna- 
mente, es capaz de evaluar la expresión 
situada entre las palabras 1F y THEN. D 
resultado de esta evaluación será un dam 
de tipo "lógico", cuyo valor sólo puede 
ser cierto o falso. 



COMPARANDO DATOS 



Las expresiones que se utilizan habitual- 
mente para imponer una condición suelen 
ser comparaciones entre datos, En la ma- 
yoría de los casos interesa ejecutar órde- 



nes distintas en función del valor de una 
determinada variable. Por ejemplo: calcu- 
lar la raíz cuadrada de una variable sólo 
cuando ésta almacena un valor positivo y 
eludir el cálculo si el valor es negativo: 

ÍF A>0 THEN RAIZ=SQR (A) 

Es evidente, pues, que se hace necesario 
contar con un método que permita formu- 
lar adecuadamente las comparaciones en- 
tre diferentes datos. 

Esta comparación se codifica en BASIC 
por medio de los siguientes operadores 

=• <, >, < >, <=, > = 

Los operadores de relación se aplican en- 
tre dos datos, constantes o variables, 
dando como resultado un valor de tipo 
lógico, esto es.: respondiendo con cierto o 

falso. 

El operador "=" evalúa la igualdad entre 
los datos especificados, de tal forma que 
si son iguales la expresión adoptará el va- 
lor cierto, y si son distintos el valor falso. 

3=3 ...CIERTO 
3=4 ...FALSO 
5=2 ...FALSO 

El operador "<" asignará el valor cierto a 
la expresión en la que se encuentre 
cuando el dato situado a su izquierda sea 
estrictamente menor que el dato colo- 
cado a su derecha. Si el valor de la iz- 
quierda es mayor o igual que el valor de la 
derecha, la expresión tomará el valor 
falso. 

3<4 ..CIERTO 
3<3 ...FALSO 
5<2 ...FALSO 

El signo ">" indica "mayor que"; es aná- 
logo al anterior, si bien, en este caso, el 
operando de la izquierda debe ser mayor 
que el de la derecha para que el valor 
obtenido sea cierto. 
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ACCION 1 



SECUENCIA 
DE 

EJECUCION 



La secuencia de elución de los programas puede sufrir alteraciones, de acuerdo al 
cumplimiento o no de condiciones impuestas por ei programador. Estas suelen adoptar la 
forma de comparaciones entre datos establecidas por medio de operadores de relación- 
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IGUAL QUE 






El operador ' igual que" (=) evalúa fa igualdad entre ios dos datos 
colocados uno a cada lado del operador. 



MENOR QUE 





La condición "menor que" (<) responde con "cierto" (Ilógico} 
cuando el dato situado a la izquierda del mismo es inferior al situado 
a la derecha del operador. 



MAYOR QUE 



1K& 



1Kg. 




> 



1Ks. 



La tercera de las condiciones básicas se concreta en la relación "mayor 
que" (>): ta respuesta es "cierto" cuando el dato situado a la izquierda 
del operador es de superior magnitud al de la derecha. 



3>3 ...FALSO 
3>4 ..FALSO 
5>2 .XIERTQ 

Los operadores definidos se complemen- 
tan con otros tres que realizan funciones 
contrarias. 

El operador complementario de ¡a igual- 
dad es el de desigualdad, cuyo signo es 
"o". Cuando los datos colocados a iz- 
quierda y derecha del referido signo sean 
distintos, el resultado de la comparación 
será cierto. 

3< >3 .., FALSO 
3< >4 ^CIERTO 
5< >2 ...CIERTO 

En definitiva: AoB será cierto siempre 
que A=B sea falso y viceversa. 
A su vez, los operadores mayor y menor 
también disponen de sus respectivos 
complementarios. Fijémonos en el pri- 
mero: ¿Cuándo no será cierto A > B? 
Naturalmente, cuando A sea inferior a B. 
Pero [cuidado!, también cuando A y B 
sean iguales. El operador capaz de evaluar 
esta condición se denomina "menor o 
igual" y su signo característico es "<- 

3<=3 ...CIERTO 
3<=4 ...CIERTO 
5<=2 ...FALSO 

El último operador de relación es el com- 
plementario de "menor que" (<). Este 
debe ser cierto cuando el resultado de 
"<" sea falso. Análogamente al caso an- 
terior existen dos posibilidades: que el 
primer dato sea mayor que el segundo o 
que ambos sean iguales. Por lo tanto, este 
operador se identificará como "mayor o 
igual" Su correspondiente signo es ">=", 
como era de esperar. 

3>=3 ...CIERTO 
3>=4 ...FALSO 
5>=2 ...CIERTO 



UN POCO DE LOGICA 



El resultado de evaluar la condición im- 
puesta en una instrucción IF, es un dato 
de tipo lógico. Sabemos que el ordenador 
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: 'abaja internamente con datos expresa- 
dos a base de ceros y unos. Estos no son 
ni más ni menos que los mismos datos 
ntroducidos, aunque codificados de 
■forma que sean inteligibles para la má- 
quina. Por suerte, el programador no tiene 
Dor qué conocer esta compleja represen- 
tación interna de ¡os datos. Cabe r sin em- 
oargo, señalar un punto relacionado con el 
:ema que nos ocupa; la evaluación de 
condiciones IF, El resultado de dicha eva- 
jación — lo que hemos dado en llamar 
dato de tipo lógico — , admite dos valores, 
2 saber: cierto o fabo. Estos se codifican 
en el ordenador en forma de "1" si la 
^es pues ta es cierto, ó "0" en el caso con- 
rario (falso). 

Desde luego, estos datos pueden ser al- 
macenados en variables numéricas, lo 
que se consigue mediante una sentencia 
:e asignación, en la cual la expresión a 
evaluar irá entre paréntesis. Por ejemplo: 

3 osrnvo=(A>=ü) 

Si el contenido de la variable A es un 
^.úmero positivo, o incluso el valor 0, la 
.aria ble POSITIVO adoptará el valor cierto 

' en el caso contrarío adoptará el valor 

i so (01 

_as variables que contienen datos de tipo 
ógicOp resultantes de evaluar una expre- 
s ón, pueden utilizarse como condiciones 
iT^tro de una instrucción IF. Por ejemplo: 

10 IF POSITIVO THEN ... 

En este caso, POSITIVO debe contener 
dato de tipo lógico (cierto o falso: 1 ó 0 
en su expresión binaria). 
Empleando este método, se pueden sim- 
: * car las expresiones de la condición 
dentro de las instrucciones IF/THEN/ 
E_SE. Así, por ejemplo, es posible in- 
troducir condiciones como la que sigue: 

' I IF A THEN ...ELSE 

t" óonde A es una variable numérica. En 
caso, cuando la variable A adopte el 
,~of 0, por efecto de la ejecución del 
: :crama, se ejecutará la zona ELSE de la 
i /jcción. Por el contrario, cuando tome 
t /alor 1 u otro cualquiera distinto de 0, 
ejecutarán las instrucciones localizadas 
s a zona THEN, al igual que sí la variable 
- .^viera en ese instante el valor lógico 
oerto, 

pues, es perfectamente factible utili- 
zar una variable numérica como condición 
y a sentencia IF, Esta es una alternativa 



POSITIVO = (A>= O) 




IF POSITIVO. 



CIERTO 



THEN. 




IF POSITIVO . 



FALSO 



ELSE. 



ra 



IF POSITIVO 



CIERTO 



THEN. 



El resultado de evaluar una condición es un valor lógico: para cierto y "O' 1 para falso. 
Este puede almacenarse en una variable numérica y ser utilizado dentro de instrucciones de 
b ifurcación condiciona L 

En el ejemplo, ta variable POSUI\ r O — cuyo valor queda establecido en la asignación 
inicial — , se utiliza para imponer la condición en la instrucción IFlTH EN / ELSE. 



particularmente útil cuando se desea reali- 
zar una acción siempre que determinado 
dato no sea nulo. Por ejemplo, sí se trata 
de evitar que e! ordenador realice una divi- 
sión por cero, puede adoptarse la si- 
guiente instrucción: 

50 IF DATO THEN SOLU=100/DATO 

El cociente (zona THEN) sólo se ejecuta 
cuando DATO sea cierto. Como quiera 
que se trata de una variable numérica, 
sólo se tomará como falsa cuando su valor 
sea cero. Por lo tanto, la división se reali- 
zará únicamente si DATO es distinto de 
cero... precisamente, lo que se pretendía. 
No hay que perder de vista que la referida 
instrucción es totalmente análoga a: 

50 IF DATO o 0 THEN 
SOLU=100/ÜATO 



El siguiente ejemplo pone en práctica los 
conceptos explicados. El programa calcu- 
lará la raíz cuadrada del número introdu- 
cido siempre y cuando éste sea positivo. 
Sí se introduce un número negativo, el 
ordenador lo rechazará y solicitará la intro- 
ducción de otro número (la raíz cuadrada 
de un número negativo es una operación 
errónea). 



10 INPUT A 

20 LET POSITIVO=(A>=0) 

30 IF POSITIVO THEN GOTO 50 

40 GOTO 10 

50 LET B=SQR(A) 

60 PRINT "LA RAIZ CUADRADA 

DE ";A; "ES: ";B 
70 END 
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CAPTACION DE DATO: 



D 



OPERADOR 
OP$ 



OPERANDO 
OP2 



(DETECCION DE OPERADOR 
Y CALCULO DEL RESULTADO 
(TOMA DE DECISION) 



C ¿OP$ = "»"?"") Q 60P$ = ^ ¿OP$= ,l » , Tj ^ ¿OF$ ="/"?) - 



PRESENTACION EN PANTALLA 



RUN 

PRIMER OPERANDO 
? ¿0 

TIPO DE LA OPERACION 

SEGUNDO OPERANDO 
?3 



RESULTADO = 120 



La figura refleja el funcionamiento del programa BASIC, incluido en ei texto, adecuado para convertir al ordenador en una calculadora. Las 
tres zonas básicas del programa se concretan en ía captación de los datos, en la detección del operador y cálculo del resultado, y en la 
presentación del mismo en la pantalla. 



En la línea 20 se asigna un valor lógico a ia 
variable POSITIVO. Esta variable se utiliza 
posteriormente como condición en la lí- 
nea 30. 



RUN 

?4 

LA RAIZ CUADRADA DE 4 ES: 2 
RUN 

M 
?25 

LA RAIZ CUADRADA DE 25 ES: 5 




UNA CALCULADORA 
A SU SERVICIO 



A modo de resumen práctico de las ins- 
trucciones de salto condicional, vamos a 
construir un programa BASIC que con- 
vierta al ordenador en una calculadora; 
elemental pero adecuada para resolver las 
cuatro operaciones aritméticas. Su em- 



pleo se reducirá a introducir el primer ope- 
rando, tras éste el tipo de operación y por 
último el segundo operando. 
El primero de los operandos se capta a 
través de la instrucción INPUT OP1. La 
variable OP1 será la encargada de guardar 
el valor del primer operando. 
El siguiente paso es introducir el tipo de 
operación que se desea realizar. Para no 
complicar el programa, las posibilidades 
se reducen a las cuatro operaciones bási- 
cas. Mediante la instrucción INPUT OP$, 
se lee el operador y se almacena en la 
variable: OPS, Por último, la instrucción 
INPUT OP2 se ocupará de leer el segundo 
operando que pasará a constituir el conte- 
nido de la variable OP2. 
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¿Qué hay que hacer para que el ordenador 
ejecute la operación solicitada? Muy fácil: 
sencillamente, poner en práctica las posi- 
bilidades de las instrucciones IF/THEN/ 
EISE. Estas deben ir comprobando las 
distintas operaciones y al coincidir el signo 
de operación con el contenido de GPS, 
ejecutar la referida operación con los da- 
ros OP1 y OP2. El resultado se guardará 
en una nueva variable cuyo nombre es 
RESUL 

Una vez realizado el cálculo, hay que pre- 
sentar el resultado en la pantalla, por me- 
dio de una instrucción PRINT. Finalmente, 
la última línea del programa ordena un 
salto incondicional al principio del mismo; 
ello hará posible realizar sucesivos cálcu- 
los sin tener que ordenar una nueva eje- 
cución. 

5 LEI RESUL=0 

10 PRINT "PRIMER OPERANDO" 
20 INPUT OPT 

30 PRINT 'TIPO OE LA OPERACION" 
40 INPUT OPS 

50 PRINT "SEGUNDO OPERANDO" 

60 INPUT 0P2 

70 1F 0P$= "+" THEN LET 

RESUL=0P1+ÜP2 
80 IF 0P$= "-" THEN LET 

RESUL=0P1-0P2 
90 IF ÜP$- THEN LET 

RESUL=0P1 *0P2 
100 IF 0P$= V" THEN LET 

RESUL- 0P1/ÜP2 
110 PRINT "RESULTAD0="; RESUL 
120 GOTO T0 



Y S! YA NO ES UTIL. 




Borra ei programa que se encuentra en 
variables definidas hasta e\ momento. 

Formato, 



dor, así como todas las 




f-jemplo: NEW 



cucíón de esta orden como instrucción 
directa, origina el borrado completo de to- 
das las líneas del programa que hubiera en 
la memoria del ordenador, así como de 
todas las variables inicializadas y utilizadas 
hasta el momento. Además, el sistema 
queda inicial izado a ta espera de que un 
nuevo programa sea introducido a través 
del teclado, o por otro medio. 

INTERRUPCION 
DE UN PROGRAMA 



La ejecución de un programa evoluciona 
de forma secuencial y ordenada, comen- 
zando por la línea de programa cuyo nú- 
mero es inferior. A partir de ésta se pro- 
cede con la siguiente, respetando siem- 
pre el orden de menor a mayor en los 
números de las líneas ejecutadas. 
Cuando el ordenador encuentra una ins- 
trucción EMD se detiene la ejecución, Esta 
instrucción suele colocarse en la última 
línea del programa. No obstante, nada im- 
pide situarla en cualquier otro punto del 
mismo. En tal caso, las lír-: : . antes 




no se ejecutarán en la secuencia lógica, ya 
que el ordenador interpreta que el pro- 
grama finaliza en la instrucción END. 
E siguiente programa incluye dos líneas 
tras la instrucción END que no serán eje- 
cutadas: 



10 PRINT J 
20 PRINT 
30 ENO 
40 PRINT 
50 PRINT 

RUN 

LINEA 10 
LINEA 20 



LINEA 10" 
'LINEA 20" 

LINEA 40" 
'LINEA 50" 



Sin duda alguna, el programa no será de 
mucha utilidad para quien posea una cal- 
culadora de bolsillo; por lo tanto, será ne- 
cesario borrarlo de la memoria del ordena- 
dor, donde ha estado almacenado hasta 
ahora 

La solución drástica es, desde luego, des- 
; néctar la alimentación de la máquina. 
Este es un método nada recomendable; 
existen procedimientos más "elegantes" 
oara borrar un programa. Uno de ellos es 
utilizar el comando NEW (nuevo). La eje- 



VARIABLES 



PROGRAMA 



NEW 



MEMORIA 



MEMORIA 



NEW es un comando BASIC que se utiliza a modo de instrucción directa (sin número de 

i mea). Su cometido es horrar de la memoria deí ordenador el programa BASIC y las variables 

almacenadas en ella. 
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Detiene la ejecución del programa en curso 
Formato: (Número de línea) STOP 
Ejemplo: 50 STOP 




El hecho de colocar una instrucción END 
en medio de un programa puede parecer 
absurdo, no obstante, llega a ser útil en 
ciertos casos; por ejemplo, si se desea 
interrumpir la ejecución bajo ciertas condi- 
ciones. El fragmento de programa que si- 
gue dará por terminada la ejecución 
cuando la variable X tome el valor cero, 

120 IFX <> OTHEN GOTD 140 
130 ENO 

140 REM CONTINUACION 

Las líneas de la 140 en adelante se ejecu- 
tarán exclusivamente cuando, al pasar por 
la comparación, X resulte distinto de 0. Si, 
por cualquier motivo, X fuera siempre 
nulo, las referidas líneas no se ejecutarían 
en ningún caso. 

EL COMANDO STOP 



En el BASIC existe otro comando desti- 
nado a interrumpir la ejecución ; éste es el 
comando STOP, Al igual que END, puede 
situarse en cualquier punto del programa; 
e incluso puede reemplazar al propio END, 
Por ejemplo: 



10 PRINT "LINEA 10" 
20 PRINT "LINEA 20" 
30 STOP 
40 PRINT "LINEA 40" 
50 PRINT "LINEA 50" 



Una vez modificada la línea 30, puede or- 
denarse la ejecución del programa, lo que 
conducirá af siguiente resultado en la pan- 
talla: 



RUN 

LINEA 10 
LINEA 20 
STOP IN 30 




La primera diferencia que se aprecia al 
comparar ambas ejecuciones reside en el 
mensaje final. Al detenerse la ejecución, 
el comando STOP muestra un mensaje de 



parada [Stop, en inglés), en el que se ín- 
dica la línea del programa en la que se ha 
producido la interrupción. Esta caracterís- 
tica puede resultar útil a la hora de depurar 
un programa, colocando instrucciones 
STOP en puntos claves del mismo. En el 
siguiente ejemplo, el programa se inte- 
rrumpe en varios puntos para, más tarde, 
visualizar en modo directo el valor de 
cierta variable. 



10 LET A= 
20 STOP 
30 LET A=A+1 
40 STOP 

50 IF A=1 THEN L£TA=2 
60 STOP 
70 GOTO 30 




Al lanzar la ejecución, el programa se de- 
tiene en la línea 20, En ese instante puede 
examinarse el valor actual de A utilizando 
una instrucción PRINT en modo directo: 



RUN 



STOP IN 20 
PRINT A 



■ 



A continuación, una vez comprobado el 
valor de A, puede retirarse del programa la 
linea 20, Ello permitirá que el programa 
llegue a ejecutar la línea 30, 



END 




La instrucción LND 
se utiliza para poner 
fin a la ejecución de 
un programa. Indica 
a la máquina que ta 
secuencia de 
instrucciones a 
ejecutar ha 
concluido y que, en 
consecuencia , puede 
abandonar el 
programa. 
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TABLA DE CONVERSION 


ORDENADOR 


JVC vv 






NEW 


STOP 


CONT 


APPLE II 

I * nni rprt 1 1 1 

(APPLESOrT) 


NLW 


o I Ur 


UUN I 


APRICOT 
(M-BASIC) 


NEW 


STOP 


CONT 


ATARI 


NEW 


STOP 


CONT 


CBM 64 


NEW 


b I Ur 


nflMT 




MUIA/ 

IMtW 


o I Ur 


LUEM I 


caí norte 
MSX 


NEW 


STOP 


::\" 


LID 1CA 

Hr-l&U 


rítw 


O I Ur 


rnwT 

LrUlX I 


IdIvI rLf 


M CIA/ 


o I Ur 


LrLMN i 


Mnr 

mrr 




ü I Ur 


„ « * 


NPR OM-V 
jvi^n mi vi v 

{MS-BASIC} 


NEW 


STOP 


CONT 


NEW BRAIN 


NEW 


STOP 


CONT 


ORIC 


NEW 


STOP 


CONT 


SHARP MZ-700 
(MZ-BASIC) 


NEW 


STOP 


CONT 


SINCLAIR QL 


NEW 


STOP 


CONTINUE 


SPECTRA VIDEO 


NEW 


STOP 


cont 


ZX-SPECTRUM 


NEW 


STOP 


CONT 




20 <RT> 
RUN 



STOP JN 40 
PRINT A 

1 




indicación, en el primer caso, de la línea 
en la que se produce la interrupción. Sin 
embargo, STOP tiene otra peculiaridad 
que lo hace más potente. Esta caracterís- 
tica está íntimamente relacionada con un 
nuevo comando: CONT. 

EL COMANDO CONT 



ja operación anterior (borrado de la línea y 
"jeva ejecución) puede reiterarse hasta 
:om probar que el valor de la variable es el 
correcto a lo largo de la ejecución del pro- 
grama. También es posible chequear y al- 
:erar cualquier otra característica que varíe 
en el transcurso de la ejecución. 
E ejemplo propuesto revela como única 
: "erencia entre el uso de STOP o END la 



De nuevo, vamos a repetir el ejemplo an- 
terior, aunque esta vez utilizando el co- 
mando CONT para reanudar la ejecución 
del programa interrumpido por medio de 
STOP. 

CONT ha de utilizarse siempre en modo 
directo. Una vez introducido y tras accio- 



nar la tecla RETURN, la ejecución CONTi- 
nuará en la línea siguiente a aquella en la 
que se detuvo. 

Con e! programa inicial sin eliminar las 
instrucciones STOP, el resultado sería el 
siguiente: 



STOP IN 20 
PRINT A 

0 




La ejecución se ha detenido en la línea 20, 
Al igual que en el caso anterior se ha 
verificado el valor de la variable A No obs- 
tante, ahora se reactiva la ejecución intro- 
duciendo la orden CONT: 




De nuevo puede visualizarse el contenido 
actual de A. Cabe observar que en este 
caso no ha sido necesario borrar la línea 
20 para, posteriormente, rei nielarla ejecu- 
ción. CONT permite continuar en la si- 
guiente línea, en este caso fa 30. Como es 
natural, el contenido actual de fas varia- 
bles no se ve alterado por el uso de STOP 
y CO NT, 

Con la ayuda de estos dos comandos es 
posible realizar un seguimiento del pro- 
grama, interrumpiéndolo en el punto de- 
seado y ordenando más tarde su reanuda- 
ción. 

Ambos comandos pueden también Utili- 
zarse para otros menesteres. Por ejem- 
plo, a la hora de detener la ejecución del 
programa para apuntar datos intermedios. 
En ocasiones y dada la rapidez de cálculo 
del ordenador, los datos pueden aparecer 
en pantalla a muy alta velocidad; es en- 
tonces cuando se aconseja el uso de 
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CONT 







ii ii i r^ffp 
— 

n i 


-i i i 



A diferencia con 
eí comando 
END, STOP no 
Si (pone la 
conclusión 
definitiva del 
programa, sino 
que sólo 
interrumpe la 
ejecución del 
mismo. Algo 
s eme jame a la 
colocación de 
una barrera en la 
trayectoria de un 
automóvil 
(secuencia de 
ejecución del 
programa). Por 
supuesto, una 
vez levantada ia 
barrera por 
efecto del 
t omando CONT, 
seguirá el avance 
de i automóvil 
í continuará la 
ejecución del 
programa . 




STOP. El siguiente ejemplo es un pro- 
grama capaz de mostrar en pantalla los 
múltiplos de 1 1 a partir de 1000. 

10 LET MUL=100T 
20 PRINT MUL 



30 LET MUL=MUL+11 
40 GOTO 20 

El bucle creado por medio de la instruc- 
ción GOTO 20 es muy rápido. En pocos 
instantes, la pantalla aparecerá repleta de 
múltiplos de 1 1 ; los primeros irán desapa- 
reciendo por la parte superior de la 
misma. Ello dificulta, cuando no hace im- 
posible, su anotación. 
Desde luego, existen otros métodos para 



OPERADORES 


DE RELACION 


OPERADOR 


RELACION 




Igual 


< 


Menor que 


> 


Mayor que 


< > 


Distinto 


< = 


Menor o igual que 


> = 


Mayor o igual que 



"congelar" la presentación en pantalla, sin 
embargo, el más directo e inmediato es el 
que recurre al uso de STOP. Por ejemplo: 

10 LET MUL-1001 
20 PRINT MUL 
25 STOP 

30 LET MUL=MUL+11 
40 GOTO 20 

Ahora, la ejecución del programa se de- 
tendrá después de mostrar cada número 
sucesivo. Ello permitirá al usuario anotar- 
los, uno a uno, e introducir la orden CONT 
para pasar al siguiente dato. 
El programa que sigue realiza la misma 
acción, si bien, su ejecución sólo se de- 
tendrá tras presentar cada grupo sucesivo 
de 20 números. 

10 REM MULTIPLOS DE 11 
20 LET MUL=1001 
30 LET C=0 
40 CLS 

50 PRINT "MULTIPLOS DE 11" 

60 PRINT 

70 PRINT MUL 

80 LET MUL=MUL-h11 

90 LET C=C+1 
100 IF C < 20THEN GOTO 70 
110 STOP 
120 GOTO 30 

Las líneas 20, 70 y 80 actúan de forma 
similar a las del programa anterior. En este 
segundo programa la clave se encuentra 
en las líneas 90 y 100. La primera de ellas 
contabiliza en la variable C los números 
presentados. La línea 100, por su parte, 
evalúa la expresión C < 20, que será 
cierta mientras la cantidad de números 
visualizados sea inferior a 20, En dicha 
situación, el programa salta a la línea 70, 
imprimiendo él siguiente múltiplo. 
La ejecución continúa con normalidad y de 
forma análoga hasta que se alcanza la can- 
tidad de 20 datos en pantall<T(C=20); ins- 
tante en el que la condición deja de ser 
cierta y, en consecuencia, deja de produ- 
cirse el salto a la línea 70. En su lugar, la 
ejecución prosigue en la línea inmediata- 
mente posterior en la que se encuentra el 
comando STOP. Así pues, el programa se 
detiene únicamente tras presentar en 
pantalla un bloque de 20 datos. 
El uso del comando CONT conduce a la 
reanudación del programa en la línea 120, 
de donde bifurcará hacia la 30. Esta última 
reinicia el contador C a cero, con lo que eJ 
programa queda en disposición de pre- 
sentar un nuevo grupo de veinte múltiplos 
de once. 
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Logo (6) 

Operadores de identificación. 
El espacio de trabajo 




demás de las posibilidades de 
manipular palabras y listas, el 
lenguaje LOGO permite reali- 
zar comparaciones e identifi- 
caciones de tipo. Los operadores integra- 
dos en este grupo, responden con TRUE 
•cierto) o FALSE (falso) como datos de 
salida. La utilidad real y práctica de estas 
salidas se verá en el capítulo dedicado al 
estudio de ios bucles. Por ahora, su come- 
tido exclusivo será identificar el tipo de 
dato con el que se está trabajando. 
Un primer operador al respecto es 
WORDP. Este responderá TRUE en el 
caso de recibir como entrada una palabra 
y FALSE en caso contrario. 
De forma análoga actúan LISTP y NUM- 
3ERP con listas y números, respectiva- 
mente. 

Un buen ejercicio es combinar estos dos 
operadores con los estudiados en anterio- 
res capítulos, para identificar el tipo de las 
salidas que entregan en cada s ..ación. 
D or ejemplo; 



EQUALP compara dos entradas y comu- 
nica si son o no iguales. 

PRINT EMPTY [ ] 
TRUE 

PRINT EQUALP" [ ] 
FALSE 

PRINT EQUALP "CASA [CASA] 
FALSE 



Un último operador de esta categoría es 
MEMBERP. Necesita dos datos de en- 
trada: el primero puede ser una palabra, 
un número o una lista, mientras que el 
segundo debe ser obligatoriamente una 
lista. 

La respuesta será TRUE si la primera en- 
trada es un elemento que forma parte de 
la lista indicada, Es evidente que su utili- 
dad se manifiesta a Ja hora de evaluar la 




TRUE 

FALSE B 



WORDP 



□□□□□□□ 



TRUE 
FALSE ■ 



I WORDPl 



V „ — ^ 

Para evaluar el tipo de dato manipulado, el 
LOGO cítenla con tres operadores adecuados 
para delectar palabras, listas y números; 
éstos son, respectivamente: WORDP. LiSTF 
v NljMRERP. 



presencia de una palabra o de una sublista 
dentro de una lista más compleja. Los si- 
guientes ejemplos, basados en la LISTA3 
definida, revelan su actuación. 



PRINT WORDP | CURSO DE BASIC] 
rALSE 

PRINT WORDP FIRST [CURSO OE BASICJ 
TRUE 

PRINT LISTP BUTLAST LIST "DON :Y0 
TRUE 

Tanto en el ámbito de las palabras como 
de las listas, cabe la nulidad; esto es: la 
oa labra vacía (") o la lista vacía ([ ]) en las 
que no interviene ningún elemento. El 
operador EMPTYP evalúa tal situación, V 
-esponde con TRUE si su dato de entrada 
reincide con una palabra o una lista vacía. 
Hay que tener en cuenta que para e¡ 
_0GO una palabra vacía y una lista vacía 
" z son la misma cosa. Ello puede comp ro- 
sarse utilizando el operador EQUALP. 




MEMBERP 



PIEZA PUZZLE 



PUZZLE. 




MEMBERP es otro de los operadores LOGO cuya respuesta es TRUE (cierto) o FALSE 
(falso). Su ejecución perntiíe confirmar la presencia de ana palabra o de ana sablista dentro de 
la lista especificada. 



129 



Lenguajes 



TRUE 



My= = ■• V | DE0 



O 



FALSE 




TRUE 



ÑAME P 



LAPIZ 



FALSE 




BLANCO 



COSA 
f 1 




AYER 
I 1 



JUAN 
I I 



VARIABLES 
LOGO 



La función del operador NAMEP es averiguar si una palabra coincide con el nombre de una 
variable previamente definida. 



PRINT MEMBERP "EL :LISTA3 
MAKE "LISTAS [EL LENGUAJE LOGO] 
TRUE 

PRINT MEMBERP [EL] :LISTA3 
FALSE 



PRINT MEMBERP 7 [1 [3] 5 [7] 9] 
FALSE 



Un método para averiguar si una palabra 
coincide con ef nombre de una variable lo 
aporta el operador NAMEP. Este admite 
un dato de entrada y responde con TRUE 
si el mencionado dato es el nombre de 
una variable previamente definida, Al igual 
que otros operadores similares, descritos 
en capítulos precedentes, su verdadera 
utilidad práctica saltará a la luz al abordar 
el estudio de los bucles. 



ALGO MAS SOBRE VARIABLES EL OPERADOR THING 



Por el momento, el trabajo con variables 
se ha centrado casi por completo en el 
uso del comando MAKE H adecuado para 
asignar un dato a la variable especificada. 
Las posibilidades de MAKE no terminan 
ahí. Cada vez que se ejecuta ef comando 
MAKE acompañado de un nuevo nombre 
de variable, éste reserva espacio para esa 
variable. 

Al respecto, cabe recordar que no es posi- 
ble utilizar una variable sin antes definirla 
previamente por medio de MAKE. 
El LOGO lleva buena cuenta de las varia- 
bles definidas. 



En algunos casos, es conveniente que el 
contenido de una variable coincida con el 
nombre de otra. Esta es una situación que 
queda ilustrada por el siguiente ejemplo. 
Una vez introducidas las dos instrucciones 
que siguen: 

MAKE "NUMERO "DIEZ 
MAKE "DIEZ 10 

para acceder aJ número 10 es preciso re- 
currir al nombre de variable :DIEZ. Esta es 
una función realizable por medio de un 
nuevo operador: THING. 



THING 'DIEZ actúa exactamente igual 
que :DfEZ, accediendo al número 10: 
THING admite como entrada la palabra 
que constituye el nombre de una variable 
y devuelve su contenido. No obstante, 
THING permite algo más. 
En el mismo ejemplo, la salida de THING 
"NUMERO será "DIEZ; sin embargo, la 
salida de THING : NUMERO, coincidirá 
con 10. En definitiva, con THING es posi- 
ble acceder al "contenido del contenido" 
de una variable. 

Un ejemplo esclarecedor lo aporta el si- 
guiente programa. Empieza con la asigna- 
ción de dos variables (dos nombres a los 
que se asigna su correspondiente número 
de teléfono). A continuación, se define un 
procedimiento al que se asocia el paráme- 
tro : NOMBRE; un procedimiento que in- 
cluye la doble posibilidad de uso del ope- 
rador THING: acompañado por un nombre 
de variable expresado como palabra 
("NOMBRE) o como variable (iNOMBRE). 



MAKE "LUIS 123 28 30 
MAKE TACO 430 26 26 
TO TELEFONO ; NOMBRE 
PRINT THING "NOMBRE 
PRINT THING :N0MBRE 
END 

TELEFONO DEFÍNED 




La ejecución evidencia las dos posibles 
actuaciones def operador THING. Al eje- 
cutar el procedimiento TELEFONO, dando 
como parámetro un nombre de variable, 
el ordenador responderá presentando el 
nombre en cuestión (PRINT THING 
"NOMBRE), seguido por el número de 
teléfono o contenido de la mencionada 
variable (PRINT THING :NOMBRE). 



TELEFONO "LUIS 

LUIS 

123 28 30 

TELEFONO "PACO 

PACO 

430 26 26 
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TABLA DE ORDENES-LOGO 


INSTRUCCION 


COMETIDO 


OPERADOR/ 
COMANDO 


VVUnU <ODjetO > 






LISTP <objeto> 


TRUE si <objeto> es una lista 


Operador 


NUMBERP < objete» 


TRUE si <objeto> es un número 




EMPTY <objeto> 


TRUE si < objeto vacío 


Operador 


EQUALP <objl> <ob¡2> 


TRUE si <obj1> v <obj2> son iguales 




MEMBERP <obj> < lista > 


TRUE si <obj> es e te mentó de < lista > 




NAMEP <palabra> 


TRUE si es nombre de variable 


Zz^z:- 


THING <objeto> 


¡ Devuelve el contenido 




EDNS 


Activa el editor de variables 


Cornando 



• objeto > puede ser una palabra o una variable. <nombre> es el nombre del procedirmenco zorrrfssj 
< varia bles > son las posibles variables locales (con dos puntos). 



Obsérvese que THING "NOMBRE equi- 
vale a : NOMBRE y que THING : NOMBRE 
equivale a THING THING "NOMBRE. 



VARIABLES GLOBALES 
Y LOCALES 



Ai hablar de procedimientos con parame- 
Tros se indicó que los parámetros de en- 
irada actúan como variables asociadas a la 
ejecución del referido procedimiento. Es- 
tas variables son de un tipo especial y 
reciben el nombre de variables locales. 
Las variables locales se diferencian de las 
restantes en varios aspectos. 

— No es preciso definirlas por medio del 
operador MAKE. 

— Su nombre no es identificado por NA- 
MEP. 

— Sólo tienen validez dentro del procedi- 
miento en el que se encuentran. 

_as variables creadas con MAKE se deno- 
minan variables globales. Ello se debe a 
que pueden ser utilizadas por todos los 
procedimientos, 

_-¿s variables globales pueden ser visuali- 
zadas y modificadas por medio del editor 
je variables, al que se accede a través del 
comando EDNS (EDit NameS). El editor 
ze variables funciona del mismo modo 



que el de procedimientos, con la salvedad 
de que también permite e::_^ = .se- 
de las variables globales. 

ESPACIO DE TRABAJO 



El espacio de trabajo (Work Spacel es el 
conjunto de procedimientos y variables, 



7h 



NOMBRE 



/ 



PROCEDIMIENTO 
TELEFONO 



TO TELEFONO: NOMBRE 
PRINT THING " NOMBRE 
PRINT THING: NOMBRE 
END 





223 21 


30 

H 


| ll; 







¿30 26 26 









Lo función del operador THING es< en 
general* devolver el contenido. El 
procedimiento reflejado en la figura, 
asociado a las variables LUIS y PACO 
— cuyo contenido son los respectivas 
números de teléfono — , Ilustra su doble 
funcionalidad . 




Al ejecutar el procedimiento l 'teléfvno'\cuyo 
parámetro de entrada es " nombre' \ se 
observa que el operador THIXG puede 
devolver tanto el nombre de la variable 
introducida como parámetro < TH ING 
"NOMBRE}* como el contenido de la misma 
• THISG SOMBRE). 

definidos por el usuario, que se encuen- 
tran en la memoria del ordenador. 
El lenguaje LOGO dispone de varios co- 
mandos para e! manejo del espacio de 
trabajo. 

E - primer lugar están los comandos que 
muestran el contenido actual del espacio 
de trabajo. Todos ellos comienzan por PO 
(Print Out): 

POTS (Print Out TitleS): muestra todos los 
nombres (títulos) de los procedimientos 
existentes en el espacio de trabajo, 

POPS (Print Out ProcedureS): visualiza en 
la pantalla el contenido de todos los pro- 
cedimientos. 

Si lo que se desea es visualizar exclusiva- 
mente el contenido de un determinado 
procedimiento, hay que utilizar el prefijo 
PO seguido por el nombre del procedi- 
miento^ Por ejemplo: 

PO "INICIAL 

mostrará en la pantalla el procedimiento 
INICIAL 

En general los referidos comandos per- 
miten ver, pero no modificar los procedi- 
mientos; para efectuar cualquier cambio 
es preciso recurrir al comando para !a edi- 
ción de procedimientos: EDIT. 
Un segundo grupo de comandos especia- 
lizados en el tratamiento del espacio de 
trabajo, está integrado por los destinados 
a visualizar las variables globales defi- 
nidas. 
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ORDENES DE CONTROL 
DEL ESPACIO DE TRABAJO 


INSTRUCCIONES 


COMETIDO 


OPERADOR/ 
COMANDO 


E = -,_ 


Borra el espacio de trabajo 


Comando 


<c=eto> 


Borra procedimiento(s) 


Comando 


z-'- e:o> 


Borra variable(s) 


Comando 


ERNS 


Borra todas las variables 


Comando 


= "S 


Borra todos los procedimientos 


Comando 


PO <objeto> 


Muestra procedimiento 


Comando 


POALL 


Muestra espacio de trabajo 


Comando 


PONS 


Muestra variables (globales) 


Comando 


POPS 


Muestra procedimientos (definiciones) 


Comando 


POTS 


Muestra procedimientos (títulos} 


Comando 


NODES 


Da el número de nodos libres 


Operador 


RECYCLE 


Reorganiza memoria 


Comando 



<objeto> puede ser una palabra o una lista 

c 



ESPACIO DE TRABAJO 



3 



PROCEDIMIENTO 



PROCED' MiENT! 



VARADLE 



VARIABLE 



VARIABLE 



VARIABLE 



PROCED. 



PROCED. 



VARIABLE 



VARIABLE 



PROCED. 



PROCED 



VARIABLE 



Ordenes LOGO 
para el con! rol 
del íf espacio de 
trabajo" O 
conjunto de 
procedimientos y 
variables, 
definidos por el 
usuario, que se 
encuentran en la 
memoria del 
ordenador. 



C 



LOGO 



PROCEDIMIENTOS- 



PO 
POTS 
POPS 



ERASE 
ERPS 



-VARIABLES - 



PONS 



ERN 
ERHS 



- TOTAL - 



POALL 



ERALL 



MODOS 
LIBRES 



KODFS 



REAG. ESP 
TRABAJO 



í RECYCLE 



PONS (Print Out NameS): muestra los 
nombres y contenidos de las variables; no 
obstante, al igual que PO y POPS, no per- 
mite su modificación. 
POALL (Print Out ALL): este es otro co- 
mando afecto al espacio de trabajo; sl 
especialidad es presentar en la pantalla e- 
contenido de todo el espacio de trabajo. 
Existe también la posibilidad de borrar una 
parte o la totalidad del espacio de trabajo. 
Los comandos utilizables para tal fin co- 
mienzan por ER [ERaseK 
ERASE: borra el procedimiento o procedi- 
mientos cuyos nombres acompañan al co- 
mando. Por ejemplo: 
ERASE "CASA 
hace que desaparezca del espacio de tra- 
bajo el procedimiento CASA. 
Tal como se ha indicado, ERASE admite 
también una lista de nombres de procedi- 
mientos; todos ellos serán borrados por 
efecto del mismo comando. 
ERPS (ERase ProcedureS): éste es un co- 
mando LOGO cuya especialidad es la de 
borrar a la vez, todos los procedimientos 
que se encuentran en el espacio de tra- 
bajo. 

Por lo que respecta a las variables, es 
posible borrar sólo algunas □ todas a la 
vez, ERN borra la variable o lista de varia- 
bles especificada, mientras que ERNS 
(ERase NameS) borra todas las variables 
de "un plumazo". Hay que señalar que 
ambos comandos eliminan tanto el conte- 
nido como el nombre de las variables, con 
lo cual, las variables borradas desapare- 
cen por completo del espacio de trabajo. 
Por último, cabe mencionar al comando 
ERALL (ERase Al I), cuya ejecución borra 
todo el espacio de trabajo. 
Cada vez que se crea un procedimiento o 
variable queda ocupada una zona def es- 
pacio de trabajo. Para conocer cuánto es- 
pacio queda aún disponible se utiliza el 
operador NODES. Este responde con el 
número de "nodos" libres. Cada nodo 
equivale a cinco bytes de memoria. 
Al eliminar procedimientos o variables se 
producen "huecos" en el espacio de tra- 
bajo ocupado. Para reordenar los procedi- 
mientos y variables hay que recurrir al co- 
mando RECYCLE. RECYCLE reúne los no- 
dos libres reagrupando el espacio de tra- 
bajo utilizado. NODES proporciona el nú- 
mero real de nodos libres si se utiliza pre- 
viamente RECYCLE. Un dato a señalar es 
que si no queda espacio suficiente a Ja 
hora de crear un procedimiento, se eje- 
cuta automáticamente el comando RE- 
CYCLE. 
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Comandos básicos del CP/M 

Comandos residentes y transitorios 
del sistema operativo CP/M 



La misión habitualmente enco- 
mendada a un ordenador es la 
ejecución de programas de 
aplicación; ya sea confeccio- 
nados por el usuario, o bien realizados por 
compañías especializadas. En todo caso, 
cuando el ordenador queda liberado de la 
ejecución de los programas, ha de ser ca- 
paz de gestionar y mantener en orden al 
conjunto de información de tipo perma- 
nente puesto en juego por las aplicacio- 
nes: programas, ficheros de datos... 
Para efectuar este control —tarea que ca- 
bría comparar con el mantenimiento y 
gestión de los archivos de una gran 
empresa — , el sistema operativo CP/M 
brinda al usuario toda una serie de herra- 
mientas en forma de comandos especia- 
les. Estos comandos pueden dividirse, 
atendiendo al elemento sobre el que ac- 
túan, en dos grandes grupos: 

• Comandos que actúan sobre fichero o 
ficheros. 

Estos comandos consideran al fichero 
como una unidad de trabajo, y en su ope- 
ración pueden copiar, eliminar o almace- 
nar en memoria, pero siempre ficheros 
completos. 

• Comandos que actúan sobre fa infor- 
mación contenida en un fichero. 

El miembro esencial de esta categoría es 
el editor del sistema operativo, con sus 
múltiples posibilidades de actuación. 
Los comandos pueden también dividirse 
atendiendo a su situación en la memoria. 
Los comandos que "habitan" en la me- 
moria centra! del ordenador y se cargan 
con el sistema operativo, se denominan 
zomandos residentes o permanentes, A 
su vez, aquellos comandos que residen en 
un disco, junto al sistema operativo, y que 
son cargados cada vez que se van a em- 
plear, reciben el nombre de comandos 
: ra ns i torios. 



LOS COMANDOS RESIDENTES 



Como ya se ha indicado, a esta categoría 
pertenecen los comandos CP/M, que son 
cargados en la máquina con el sistema 
operativo, y permanecen en ¡a memoria 
central mientras no se desconecte el or- 
denador. Los más relevantes son tos que 
se relacionan a continuación. 

DIR 

Su misión es mostrar el catálogo de ¡os 
ficheros contenidos en un disquete. 
Adopta el siguiente formato: 

A>D!B x: 

El parámetro x representa eJ nombre de la 
unidad en la que se encuentra e! disco del 
cual se desea obtener el catálogo de fi- 



cheros; puede ser un número o una letra, 
dependiendo del criterio de nomenclatura 
empleado. Este nombre puede omitirse, 
en cuyo caso se mostrará el catálogo de la 
unidad que el sistema considere por de- 
fecto (normalmente la principal del sis- 
tema). 

La orden admite también referencias am- 
biguas, lo que permite buscar los ficheros 
de un nombre específico. Por ejemplo: 
A>DÍR B: *. BAK 

Su ejecución proporcionará el catálogo de 
todos los ficheros del tipo BAK conteni- 
dos en el disco alojado en la unidad de 
lectura B. 

ERA 

Su utilidad reside en el borrado de un fi- 
chero del disco. En la actualidad, el pro- 
ceso que se sigue no es un borrado es- 
tricto del fichero, puesto que no se eli- 
mina la información; en realidad, se co- 
loca un indicador en la cabecera del fi- 
chero, revelador de que los datos son ob- 
soletos e inutilizares. Este espacio queda 
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Los comandos del CFfM actúan sobre los ficheros almacenados en ¡a memoria del ordenador 
en cada instante. En consecuencia, para que sea posible utilizarlos con eficacia, es preciso 
trasladar los archivos a tratar desde el disco hasta la memoria central del equipo. 
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así disperto e pera reescribir en él un 
nueve ' c~^z. 
EJ formato de Ja orden es: 
A>ERA x: Nombre del fichero. Tipo 
. "t t: :-:cjcida esta orden en la má- 
quina, se borrará el fichero cuyo nombre 
í~ es:e; ^ zs y que se encuentra almace- 
" 7. :. : t - : squete situado en la unidad x. 

^e.c es posible utilizar referencias 
ambiguas para especificar más de un fi- 
chero, 

Eb conveniente ejecutar una orden DIR 
antes de utilizar el comando ERA. El mo- 
tivo no es otro que comprobar previa- 
mente la existencia de los ficheros que se 
desea eliminar. Asimismo, es conve- 
niente utilizar el comando DIR a posteriori, 
para comprobar que el borrado se ha reali- 
zado de forma correcta. 

REN 

REN se emplea para otorgar un nuevo 
nombre a un fichero. La forma que adopta 
esta orden es: 

Á>RENx: Nuevo nombre. Tipo = Antiguo 
nombro. Tipo 

La referencia x identifica a la unidad en la 
que se encuentra el disquete que con- 
tiene el fichero. En el contexto de esta 
orden, no cabe utilización de referencias 
ambiguas, ya que no 3o permite el sistema 
operativo CP/M. 

SAVE 

Se utiliza para trasladar a disco el conte- 
nido de la memoria central. La informa- 
ción que se transmite al disco se encuen- 
tra almacenada en el área de la memoria 
primaria destinada a los programas de 
usuario (TPA). El formato de esta orden es 
el que se índica a continuación: 
A>SAVE Yx: Nombre de fichero 
En esta ocasión, x representa la unidad en 
que se encuentra el disquete que recibirá 
los datos, mientras que Y representa el 
número de páginas de memoria que se 
desea almacenar. En el contexto del sis- 
tema operativo CP/M, la página es un 
conjunto de 256 caracteres. A la hora de 
utilizar el comando SAVE, hay que adoptar 
dos precauciones. La primera de ellas es 
reparar en que esta orden borra cualquier 
fichero cuyo nombre coincida con el espe- 
cificado; de ahí que sea conveniente acti- 
var el comando DIR con anterioridad. La 
segunda, supone definir con exactitud el 
número de páginas de memoria a guar- 
dar; con ello se conseguirá ahorrar espa- 
cio dé disco. Af respecto, cabe señalar 
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A diferencia con (os residentes* los comandos transitorios del CPIM sólo se cargan en la 
memoria central del ordenador vitando son invocados por el usuario desde el teclado. 



que existen órdenes especiales que reve- 
lan la distribución de los datos almacena- 
dos en la zona TPA. 

TYPE 

El cometido de TYPE es visualizar ficheros 
que contengan caracteres imprimibles. 
Unicamente permite su visualización; la 
modificación de los datos contenidos en 
ef fichero es tarea del editor del sistema 
operativo o de un programa de trata- 
miento de texto, dependiendo del tipo de 
datos que residan en el mismo. Su for- 
mato es: 



A>TYPEx: Nombre del fichero 
En la expresión, x identifica a la unidad en 
que se encuentra el disquete que atoja al 
fichero. 

CONTROL-C 

Constituye la orden de "arranque en ca- 
liente" del sistema operativo CP/M. Este 
comando se introduce pulsando simultá- 
neamente las teclas <CTRL> y C. 
El efecto que produce es el de restaurar la 
configuración de la memoria a un estado 
predefinido. Sus funciones principales 
son: 



134 



s.o. 



a. La interrupción de un programa en 
curso de ejecución y el regreso al nivel de 
órdenes propias del CP/M. 

b. Catalogar un nuevo disquete cuando 
se introduce en una de las unidades de 
lectura. 

CONTROL-E 

Este comando se utiliza para indicar al or- 
denador que las órdenes que recibe en 
una línea continúan en la siguiente. Se 
introduce pulsando simultáneamente las 
teclas <CTRL> y E. 

CONTROL-P 

Su misión es activar o desactivar la impre- 



sora, dependiendo del estado de la 
misma. Cuando la impresora se activa, las 
salidas por pantalla también se reprodu- 
cen en Ja impresora. Se introduce pul- 
sando las teclas <CTRL> y P a! ynísono. 

CONTROL-X 

La misión de CONTROL-X es cancela* e 
impedir que el ordenador ejecute una se- 
rie de órdenes introducidas a través dd 
teclado. Se emplea normalmente cuando 
el número de errores de meca" zg~a z a 
elevado y, por lo tanto, es más caz: :: 
empezar de nuevo la introducción. En 
gunas versiones de CPyM-30 f concreta- 
mente la 1.3, se sustituye la X por U a Ja 
hora de teclear la mencionada orden. 



COMANDOS TRANSITORIOS 



Los comandos transitorios se encuentran 
almacenados, habitualmente, en disco. 
Sólo se cargan en la memoria central y se 
ejecutan cuando son invocados específi- 
camente. En la práctica, estos comandos 
se comportan como si fueran programas, 
ignorando completamente al CP/M; sólo 
regresan a ese nivel tras su ejecución. 
Algunos de estos comandos exigen una 
serie de parámetros complementarios. 
Estos se introducen a continuación del co- 



El editor del sistema operativo CP/M 



La escritura de un programa o la 
modificación de un fichero es una tarea 
cotidiana para el programador o para el 
usuario avezado. A través del teclado del 
ordenador, se van introduciendo las 
distintas sentencias de que consta el 
programa, o los datos que deben engrosar 
el fichero; sentencias y datos que son 
visualizados sobre la pantalla y modificados 
o corregidos por la acción de ciertas 
órdenes dadas a través del teclado. 
El Editor es el programa que apoya al 
usuario en estos menesteres: toma los 
caracteres del teclado y los presenta sobre 
el monitor, permite corregir los errores que 
puedan cometerse durante el proceso de 
escritura (brindando órdenes que 
modifican, eliminan o aumentan la 
información que se ha tecleado)..., y se 
ocupa de transmitir esta información al 
disco o a la memoria secundaria del 
ordenador, una vez concluido el proceso de 
edición. 

En el sistema operativo CP/M la gestión de 
las modificaciones y, en general, de la 
edición de un fichero, se apoya en una 
partición de la memoria denominada 
"buffer del editor''. En esta partición se 
carga el fichero fuente u original a modificar 
(al que denominaremos, sencillamente, 
"fichero"), al tiempo que se genera en el 
disco un fichero vacío, de nombre: 
fichero. $$$. 

Sobre la información contenida en este 
buffer es, precisamente, donde actúan Jos 
comandos activados a través del teclado. 
Una vez que se estima correcto el 
resultado, se dará la orden para almacenar 
el fichero. En este preciso instante ocurren 
dos procesos simultáneos. El primero es el 
trasvase de la información contenida en el 
buffer de memoria hacia "fichero. SS$", el 



cual cambia su nombre por el fichero 
fuente original, y se almacena como e» 
nuevo fichero fuente. El segundo proceso 
coincide con el cambio de nombre del 
antiguo fichero fuente, que oesa s 
denominarse fichero SAZ , :. ir - ---- 
'back-up r ¡copia de seg^' ziz :e 
fichero. A raíz de este último proceso, ka 
información queda duplicara a~ a 



por lo tanto, resultará difícil su borrado o 
pénfda accidental. 

Si el tamaño del fichero es superior al del 
i _ Xl -- -■= — = — r- = a — é~z-co que se sigue 
es idéntico, con la única salvedad de que ei 
fichero es actualizado por etapas y el 
cambio en el nombre de Jos ficheros se 
realiza al actualizar la última porción del 
mismo. 




y 
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Ficheros mci nipit lados 
por el 1 'editor' ' del 
CPÍM. 
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APLICACIONES DEL COMANDO STAT 




Significado 


STATx: 

STATx: Nombre fichero 

STAT x: DSK 
STAT x: R/O 
STAT log:=phy 


Indica el espacio libre en el disco del dispositivo x. 

Indica el espacio ocupado en el disco por el fichero. 

Hace visible la asignación actual entre dispositivos físicos y lógicos. 

Visualiza las posibles asignaciones de dispositivos físicos y lógicos. 

Visualiza la información referente a cómo se almacenan los datos en 

el disco del dispositivo x. 
Asigna al disco del dispositivo x una protección de forma que sólo 

pueda leerse información. 
Asigna el dispositivo físico phy al dispositivo lógico log P 




SUBCOMANDOS DEL EDITOR (ED) 


Comando 


Significado 


#A 

E 

H 

0 

Q 

nK 

nL 

U 

V 


Añade líneas del fichero original al buffer de editor, 
Fin de la sesión de edición. 

Localiza el principio del fichero que se está editando, 
Borra el fichero editado. 

Fin de la sesión de edición. Los ficheros no se modifican. 

Elimina n líneas del fichero. 

Avanza n líneas el cursor. 

Transforma minúsculas en mayúsculas. 

Visualiza números de línea. 




PARAMETROS BASICOS DEL COMANDO PIP ! 


Parámetros 


Significado 


D# 

E 

G# 
U 

N 

V 


Suprime todos los caracteres que sobrepasen en la transferencia de 

información la columna #-ésima. 
Eco en la consola al realizar una copia. 

Permite la copia de ficheros desde áreas de usuarios distintas a la 
usada. 

Convierte letras minúsculas a mayúsculas en la transferencia de 
información. 

Almacena añadiendo números de línea a cada línea. 
Verifica que Ja copia es correcta 




Los comandos del CPjM permiten organizar 
v mantener en orden ios archivos de 
información almacenados en el ordenador. 




Ei editor engloba a las herramientas que 
brinda el sistema operativo CPIM para la 
escritura y modificación de los datos 
me mor izados en ¡os ficheros. 



mando y antes de pulsar la tecla de retro- 
ceso de carro (RETURN o ENTER). El for- 
mato general de esta orden es el que se 
indica a continuación. 
A> Comando Parámetros 
STAT 

Pueden suministrar información acerca de 
ficheros o grupos de ficheros, o bien infor- 
mación relativa a dispositivos físicos y ló- 
gicos del CP/M. Cabe precisar que los 
dispositivos lógicos coinciden con funcio- 
nes como,, por ejemplo; introducción de 
órdenes, recepción de información, envío 
y listado de información... 

PIP 

El comando PIP es un comando destinado 



a la copia de información de una zona a 
otra de fa memoria central, entre dispositi- 
vos periféricos o de un fichero a otro. 

ED 

ED es el comando adecuado para llamar al 
editor del sistema operativo CP/M. Por 
medio del editor es posible modificar y 
crear ficheros de datos y programas. Una 
vez invocado, el editor opera gobernado 
de una serie de parámetros que permiten 
funciones tales como eliminar o añadir lí- 
neas y caracteres. Algunos de los referi- 
dos parámetros aparecen definidos en el 
cuadro adjunto. 

SUBMIT 

La tarea del comando SUBMIT es instruir 



al ordenador para que ejecute una serie 
de órdenes del sistema operativo CP/M, 
sin que exista intervención por parte del 
operador. Para ello se crea un fichero, de 
nombre "Nombre de! fichero. SUB", por 
medio del editor del sistema operativo. En 
este fichero se escriben los diferentes co- 
mandos — uno por línea — r que han de ser 
ejecutados. Una vez cerrado el fichero, y 
para que se ejecute el conjunto de órde- 
nes que contiene, es preciso teclear: 

A>SUBMÍT Nombre del fichero SUB 

La utilidad de este comando reside en la 
interesante posibilidad de ejecutar con- 
juntos de órdenes de tipo repetitivo, con 
comodidad y sin exigir la atención parcial 
del usuario. 
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Wordstar (2) 

El complemento MAILMERGE. 
Instalación y prueba del tratamiento de textos 



ras la definición y el estudio de 
los principales comandos, aco- 
metido en el primer capítulo 
dedicado al WORDSTAR, 
¡lega el momento de analizar las opciones 
complementarias y la forma de instalación 
y prueba inicial de este tratamiento de 
textos. 

ES complemento básico del WORDSTAR 
lo aporta ef paquete MAILMERGE, orien- 
tado a la producción de cartas y otros do- 
cumentos especiales, 

MAILMERGE 



Este es el nombre que recibe un paquete 
de aplicación, complementario del 
WORDSTAR y concebido como opción 
del mismo, cuya especialidad reside en la 
edición de cartas en serie ("mailings"}. 
Puede adquirirse ¡unto al WORDSTAR, o 
bien separado del resto de la aplicación. 
Cabe señalar que la ejecución de este pa- 
quete complementario impide simulta- 
near fa impresión de un documento y la 
edición de otro texto distinto. En conse- 
cuencia, al ejecutar el comando MAIL- 
MERGE se entrará en estado de impre- 
sión, y hasta que ésta concluya, el proce- - 
sador no podrá dedicarse a ninguna otra 
función. 

Por supuesto, las posibilidades del MAIL- 
MERGE incluyen por completo todas las 
propiedades de impresión del WORD- 
STAR, descritas en ef capítulo anterior. Si 
bien, ofrece además una serie de opcio- 
nes adicionales entre las que cabe señalar 
ías siguientes: 

7. Ficheros de datos 
Se utilizan para almacenar listas o cual- 
quier otra información que debe inser- 



tarse en documentos medíante el MAIL- 
MERGE. Para crear y/o modificar estos 
ficheros se puede utilizar la opción normal 
de edición del WORDSTAR, aunque tam- 
bién puede emplearse un programa adi- 
cional, do la firma MIC^C— C o-:ysizz 
de capturar datos: el DATASTAR. 
Una tercera posibilidad para gestionar tos 
ficheros de datos, consiste en realizar pro- 



gramas de usuario adecuados para realizar 
el oportuno tratamiento de los mismos. 

Z Toma extema de datos 
Es:s opción sirve para insertar informa- 
ción variable en un documento, e imprimir 
un ejemplar del mismo con los datos to- 
mados del exterior. Un típico ejemplo de 
toma externa de datos, realizable me- 






MAIL 
MERGE 
















El paquete de aplicación MAILMERGE es un complemento del tratamiento de textos 
WORDSTAR. Su presencia permite realizar determinadas junciones especiales muy útiles, 
particularmente, a la hora de producir cartas en serie (mailings). 
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DATOS 2 ¡ 





MAIL MERGE 



DOCUMENTO 
UNICO 



Una de tas funciones primordiales del MAILMERGE consiste en la conjunción del con fe nido 
de vatios archivos de información en un único documento escrito. 



FACTURA 
0 



Pts.- 



LUIS RUIZ 1DG.Q0Ü 

JOSE ROS 50.000 




J FACTURA 
; n LUIS RUIZ 



# p ts 100. 000 
• 

* FACTURA 
l n JOSE ROS 



Pts.. 



50. 000 



Una de las posibilidades más relevantes del MAILMERGE es la producción en serie de carias; 
"cruzando" un archivo de datos con el archivo que almacena el texto común, 



diante el MAILMERGE, es la producción 
de cartas personalizadas. A partir de un 
texto básico, a incluir en todas las cartas, 
se sustituirán determinados "huecos" por 
datos externos, por ejemplo: el nombre y 
ia dirección de la persona a quien se dirija 
la carta. 

La información a insertar puede obte- 
nerse de un fichero de datos como el 
señalado anteriormente. Sin embargo, 
también puede ser introducida directa- 
mente por el operador a través del te- 
clado, e incluso pueden determinarse va- 
lores al principio del documento para que 
se inserten en varios sitios del mismo. 
Para controlar la fusión de los datos exter- 
nos con el texto básico de la carta, se 
utilizarán controles embebidos en dicho 
texto. En todo caso, tanto la edición del 
texto básico como la de los controles, se 
efectuará a través de las funciones de edi- 
ción del WORDSTAR. 

3. impresión en cadena 
Cuando un documento es de gran ta- 
maño, puede resultar incómodo editarlo 
desde un único archivo de datos. En este 
caso r el MAILMERGE permite que un do- 
cumento "llame" a otro archivo de docu- 
mentos por su nombre; de esta forma, 
será posible imprimirlos en cadena. 
Tal posibilidad también resulta útil cuando 
se utiliza una frase o párrafo de forma muy 
repetitiva en uno o más documentos; es- 
tas porciones de texto se pueden guardar 
en archivos separados y pueden ser "lla- 
madas" por tantos documentos como sea 
necesario. 

Otro método para gestionar la impresión 
en cadena de varios textos, pasa por la 
creación de un archivo de control; éste 
almacenará los documentos adecuados 



para imprimir las distintas partes de un 
mismo documento. 

4. Obtención de múltiples copias 
El WORDSTAR dispone de vahos méto- 
dos para obtener varias copias de un do- 



cumento. Uno de ellos consiste en la in- 
clusión de comandos destinados a la pro- 
ducción de varias copias repetidas; si se 
desea que el número de copias sea varia- 
ble, puede especificarse esta circunstan- 
cia a través de comandos al efecto. Por lo 




Lú impresora es el periférico que plasma la tarea desarrollada 
por el usuario con la colaboración del paquete para el tratamiento 
de textos. Esta puede ser de diverso tipo y capaz de obtener 
copias de mayor o menor calidad. 



Para el tratamiento de textos, es conveniente que el 
ordenador esté complementado por una doble unidad de disco 
que permita obtener cómodamente copias 
de seguridad de los archivos* 
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demás, el usuario de MAILMERGE puede 
decidir la repetición de un documento tan- 
tas veces como estime oportuno, 

5. Comunicaciones con eí operador 
Esta facilidad permite que, durante la im- 
presión de un documento, el WORDSTAR 
pueda escribir mensajes destinados al 
operador; pidiéndole que complete cierta 
información, o que active un tipo especial 
de papel continuo, La comunicación entre 
procesador y operador se establece me- 
diante comandos especializados, inserta- 
dos en el archivo que contenga ei texto, 

6. Formateo durante ía impresión 

El formateo estándar se realiza mediante 
ei WORDSTAR durante la ecritura; no 
obstante, se puede utilizar la opción 
MAILMERGE, de tal forma que quede 
abierta la posibilidad de insertar informa- 
cíón variable en determinadas posiciones 
del texto, 

INSTALACION QEl WORDSTAR 



Para que el WORDSTAR pueda funcionar 
en un ordenador personal, hay que consi- 
derar ciertos requisitos mínimos en 
cuanto a instalación. Básicamente, son 
necesarios fos siguientes elementos; un 
ordenador personal con suficiente memo- 
ria RAM y equipado con el sistema opera- 
tivo adecuado (CP/M o MS/DOS), una 
unidad para disco flexible (o unidad de 
disco rígido), un terminal [teclado y panta- 
lla), una impresora y, por supuesto, la apli- 
cación para el tratamiento de textos 
WORDSTAR. 

Contenido del paquete WORDSTAR 
Junto con el paquete de aplicación 
WORDSTAR, se recibe una documenta- 
ción para su manejo y un disco flexible 
que incluye los siguientes archivos: 
— WSU-COM, Contiene información ne- 
cesaria para proceder a la instalación del 
WORDSTAR. 

— MAILMERGE-OVR, Contiene informa- 
ción necesaria para proceder a la instala- 
ción del MAILMERGE. 
— INSTALL-COM. Programa de instala- 
ción que utilizará el archivo WSU-COM y 
MAILMERGE-OVR. 



Impresoras para procesos 
de textos 



Uno de los elementos hardware más 
importantes para, realizar el tratamiento de 
textos es la impresora; el periférico 
encargado de obtener la copia escrita de los 
textos procesados. De ella dependerá la 
calidad final de los documentos 
producidos; de poco servirá disponer de 
una aplicación potente y ágil, si el periférico 
en que finalmente se imprime ei resultado 
no es satisfactorio. 
Dentro de la enorme cantidad de 
impresoras disponibles en e\ mercado 
informático, cabe distinguir los siguientes 
tipos básicos 

impresoras de bola 
Trabajan con una bola —de ahí su 
nombre — que contiene todos ¡os 
caracteres que pueden ser escritos. La 
impresión en este tipo de periférico se 
realiza carácter a carácter y, por lo tanto, su 
vetóiad sueVe ser retativameTite baja. A 
cambio de esta lentitud, ofrece una 
escritura de alta calidad. 
El mecanismo para la escritura de cada 
carácter, se fundamenta en el giro de la 
bola, de tal forma que el carácter a escribir 
quede en la posición de escritura 
enfrentado al pape!. 

impresoras de matriz de puntos 
En este caso r la escritura de cada carácter 
corre a cargo de una matriz de agujas. 
Activando y desactivando los distintos 
puntos de la matriz se obtendrá la 
impresión de carácter que se desee. 
Dentro de las impresoras de matriz de 
puntos, existen dos tipos fundamentales; 
ambos permiten obtener informes escritos 
de inferior calidad a la que se logra con 
impresoras de bola. Eí primer tipo se basa 
en la escritura carácter a carácter, mientras 
que las impresoras del segundo tipo 
escriben simultáneamente todos los 
caracteres de una línea. En todo caso, la 
velocidad de impresión es bastante más 
elevada que la disponible en las impresoras 
de bola. 

Impresoras de banda 
La impresión se realiza por medio de una 
banda de acero que contiene todos los 
caracteres generales. Esta gira 
continuamente a gran velocidad de forma 
que, en el momento oportuno, un pequeño 
golpe producido por un martillo permite la 
impresión del carácter en el papel. El 
martillo empuja a la banda de acero contra 
una cinta entintada que se encuentra entre 
la banda y el papel. 



impresoras de margarita 
Junto con las de bola, las impresoras de 
margarita son las que producen 
documentos finales de más alta calidad. El 
dispositivo de escritura es una rueda, 
denominada margarita, cuyos brazos 
contienen los distintos caracteres. Para 
imprimir uno de ellos, la margarita se 
posiciona de tal forma que r mediante un 
pequeño impulso de un martillo, el brazo 
con el carácter adecuado golpea la cinta 
entintada contra el papel. 
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BANDA 




MARGARITA 



Mecanismos básicos utilizados por las 
impresoras de bofa, matriz de puntos, 
banda y margarita. 
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ARCHIVO 



MAILMERGEjJ 

d o. 



¿CUANTAS COPIAS 
DESEA OBTENER? 



Para facilitar la comunicación con el operador, es posible insertar comandos en el archivo. De 
esta forma, antes de proceder a su escritura, el ordenador pedirá a! usuario que matice la 
tarea a realizar, 



1 

- 84 


i ^ 

S 


. 1 


J 



-250- 



El tratamiento de textos WORDSTAR puede 
trabajar con pantallas de un mínimo de 16 
líneas por SO columnas y un máximo de ¡20 
líneas por 250 columnas. 



— WSMSGS.OVR. Mensajes del WORD- 
STAR. 

— WSOVIY 1.0VR. Mensajes del WORD- 
STAR. 

Dado que el "paquete" MAILMERGE es 
opcional, el archivo MAJLMERGE-OVR 
sólo estará incluido si, en efecto, se ad- 
quiere junto al WORDSTAR. En el caso de 
que la compra se haga por separado, se 
recibirá un nuevo disquete con el archivo 
correspondiente. 

Características del ordenador personal 
Un primer condicionante básico del orde- 
nador personal que se utilice para "sopor- 
tar" al WORDSTAR, es ef tamaño de su 
memoria RAM; por supuesto, cabe dar 
por descontado que su sistema operativo 
es capaz de "aceptar" [a aplicación. 
EJ volumen mínimo de la memoria de lec- 
tura/escritura es de 48 Kbytes, incluyendo 
espacio para el sistema operativo y áreas 
para el almacenamiento de texto. 
Si se desea simultanear la impresión de 
texto con la edición de otros archivos, es 



necesario disponer de 3 Kbytes adiciona- 
les. En cualquier caso, si se pretende sa- 
car un buen partido de todas las posibilida- 
des que ofrece el WORDSTAR, es reco- 
mendable disponer de más espacio de 
memoria principal del estrictamente 
necesario. 

Es importante no confundir el concepto 
memoria RAM (memoria principal del or- 
denador que permite la lectura y escritura 
de información) con memoria secundaria 
o de masa (memoria auxiliar externa, habi- 
tualmente a base de discos flexibles). 

Características def terminal 
Puede utilizarse cualquier tipo de termi- 
nal, siempre que Ja pantalla tenga un mí- 
nimo de 16 líneas y 84 columnas y un 
máximo de 120 líneas por 250 columnas. 
También es necesario que utilice el có- 
digo ASCII y sea capaz de posícionar el 
cursor en cualquier punto de la pantalla. 
Como características adicionales con- 
viene que permita Ja inserción y borrado 
de líneas, y que posea atributos de cam- 
pos, tales como inversión video, parpa- 
deo, realce de intensidad, etc. 
En ef caso más frecuente, el teclado y la 
pantalla forman parte de la configuración 
básica def propio ordenador personal. No 
obstante, ciertos equipos constan exclusi- 
vamente de la unidad central y exigen la 
adopción de un terminal independiente. 
Para que el WORDSTAR pueda funcionar 
con el terminal elegido, hay que especifi- 
car las características de dicho terminal 
respondiendo a un menú durante el pro- 
ceso de instalación. 

Características de la impresora 
El WORDSTAR puede utilizar práctica- 
mente cualquier tipo de impresora de las 



existentes en el mercado. Por supuesto 
las funciones de la impresora van a de:e - - 
minar la viabilidad o inviabilidad de algunas 
de las opciones de impresión del procesa- 
dor de textos. Por ejemplo, para escrifc 
un documento con letra negrilla y subn 
vado, es imprescindible que la impres 
acoja ambas posibilidades. 

Características de fas unidades de disc 
flexible 

Para la cómoda y eficaz manipulación 
los archivos, es imprescindible contar i 
una unidad de disco simple o doble (c, 
capacidad para uno o dos disquetes). En e 1 
primer caso, si sólo se dispone de una 
unidad, será posible trabajar correcta- 
mente, si bien, no quedará abierta la op- 
ción de realizar copias de seguridad que 
garanticen la conservación de los archivos 
en ef caso de que se estropee un disco de 
trabajo. Con una doble unidad de disco 
queda solventado tal inconveniente. El es- 
pacio recomendable para el almacena- 
miento de archivos es de 70 Kbytes para 
ficheros especiales del WORDSTAR, más 
el adecuado para el almacenamiento de 
los archivos a editar. 



PRUEBA DEL WORDSTAR 



Cuando se activa el WORDSTAR, ya sea 
de forma automática al finalizar su instala- 
ción, o bien al invocarlo escribiendo WS, 
debe borrarse el contenido de la pantalla 
de forma automática y aparecer en ella el 
mensaje inicial. En este último figurará ef 
número de la versión y el número de serie 
del paquete de aplicación. Después de al- 
gunos segundos, o tras accionar cualquier 
tecla, debe aparecer el denominado menú 
sin archivo. En este punto conviene reali- 
zar algunas pruebas básicas: 
—El posiciona miento del cursor 
— El archivo de mensajes. 
— La función de borrado. 
— La función de superposición. 
— La función de edición. 
— El funcionamiento de la impresora. 
Una vez finalizada la comprobación de es- 
tas características, puede ya dar comienzo 
la sesión de trabajo con uno de los proce- 
sadores de textos más potente y comple- 
tos que existen en el mercado. 
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Programando bucles 

Estructuras cíclicas y 

decisiones de múltiple alternativa 



la hora de adentrarse en los 
secretos de la programación 
hay que disponerse a fran- 
quear con éxito el estudio de 
las estructuras de control. Este es uno de 
os aspectos más importantes de la pro- 
gramación en lenguaje BASIC, 
Las estructuras de control llevan asocia- 
das una serie de instrucciones cuya fun- 
ción primordial es la ruptura de la secuen- 
cia de ejecución normal del programa. Es- 
°.as instrucciones permiten crear progra- 
mas capaces de tomar decisiones en base 
a criterios establecidos por el programa- 
dor. El resultado de la decisión puede lle- 
var a ejecutar o no una determinada zona 
deJ programa, o bien puede controlar ¡a 
ejecución repetitiva de una rutina un de- 
terminado número de veces. 
Por el momento, las instrucciones BASIC 
de este tipo sometidas a examen se redu- 
cen a dos: GOTO (salto incondicional) e 
IF/THEN/ELSE (bifurcación condicional 
con toma de decisión). Este repertorio de 
instrucciones de control se completa en el 
presente capítulo con dos nuevas incorpo- 
raciones: FOR/NEXT y ON/GOTO. 



PROGRAMACION DE BUCLES 



El objetivo de un programa BASIC puede 
ser, sencillamente, calcular el importe to- 
la I de tres artículos de distinto precio uni- 
tario y adquiridos en distinta cantidad. La 
forma de escribir o codificar un programa 
semejante, empleando el lenguaje BASIC, 
no plantea excesivos problemas. Una po- 
sible solución es la siguiente: 



10 LET T-Q 

20 INPUT "CANTIDAD DEL ARTICULO"; C 
30 INPUT "PRECIO DEL ARTICULO"; P 
. 40 LET N=C*P 
50 PRINT "CANTIDAD A PAGAR:"; N 
60 LETT-T+N 

70 ÍNPUT "CANTIDAD DEL ARTICULO"; C 
80 INPUT "PRECIO DEL ARTICULO"; P 
90 LETN=C*P 

100 PRINT "CANTIDAD A PAGAR:"; N 
110 LET T=T+N 

120 INPUT "CANTIDAD DEL ARTICULO"; C 
130 INPUT "PRECIO DEL ARTICULO"; P 
140 LET N = C*P 

150 PRINT "CANTIDAD A PAGAR:"; N 
160 LET T=T-1-N 

170 PRINT "EL TOTAL A PAGAR ES;";T; 

"PESETAS" 
180 END 

El programa resulta un tanto extenso, 
aunque, sin fugar a dudas, realiza la fun- 
ción encomendada. 

La primera instrucción (10 LET T=Q) pone 
a cero la variable que irá totalizando los 
importes o cantidades a pagar por los di- 
versos artículos adquiridos. La zona deli- 
mitada por las instrucciones 20 a la 60 



solicita la introducción de la cantidad (C) y 
precio (P) del primero de tos artículos; tras 
elfo, calcula el importe total del mismo (40 
LET N=C*P) y lo almacena en la variable T 
(60 LET T=T-hN). 

Como quiera que son tres los artículos 
que se adquieren, el programa repite la 
mencionada zona (instrucciones 20 a la 
60) dos veces más (líneas 70 a la 1 1 0 y 
120 a ta 160), Por último ya sólo queda por 
presentar en la pantalla el importe total de 
la compra, memorizado en la variable T; 
de ello se encarga la instrucción 170. 

Veamos un ejemplo de ejecución: 



RUN 

CANTIDAD DEL ARTICULO? 2 
PRECIO DEL ARTICULO? 5 
CANTtDAD A PAGAR; 10 
CANTIDAD DEL ARTICULO? 5 
PRECIO DEL ARTICULO? 1 
CANTÍDAD A PAGAR: 5 
CANTIDAD DEL ARTICULO? 4 
PRECIO DEL ARTÍCULO? 3 
CANTIDAD A PAGAR: 12 
EL TOTAL A PAGAR ES: 27 PESETAS 




El simple cálcalo del 
importe total de una 
compra de tres 
artículos, de distinto 
precio unitario, 
constituye un 
ejemplo adecu&do 
para estudiar las 
ventajas que aportan 
los bucles o 
estructuras cíclicas 
a la programación 
BASfC, 
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ü 



x 5 Pts 





xl Pts 




x 3 Pts 




La moderación de la compra realizada 
hace que el programa no plantee ninguna 
dificultad. ¿Pero qué sucede cuando el nú- 



El método más directo consiste en calcular 
por separado el importe total de cada 
artículo y totalizar la suma final. El 
programa al efecto no incorpora bucle 
alguno, sino que repite en tres ocasiones la 
misma operación antes de evaluar ía suma 
final. 



mero de productos es mayor? Suponga 
que se realiza una compra de más de cien 
productos o artículos distintos. Es evi- 
dente que la estructura del programa an- 
terior no resultará adecuada. ¿Existe algún 
método que permita confeccionar el pro- 
grama adecuado sin recurrir a la tediosa 
tarea de escribir una y otra vez idéntico 
bloque de operaciones? 
Desde luego que hay soluciones- Este es 
precisamente uno de los cometidos fun- 
damentales de las estructuras de control. 
Su puesta en práctica permite crear bu- 
cles en el programa cuya ejecución puede 
repetirse tantas veces como sea preciso. 
Una posible alternativa, bastante más ra- 
cional, es la que propone el siguiente pro- 
grama: 

10 LET T=0 
20 LET NO 

30 INPUT "CANTIDAD DEL ARTICULO"; C 



TOTAL A PAGAR 



CONTADOR DE CICLOS 




BUCLE 
DE CALCULO 
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IMPORTES 
SUCESIVOS 




Con la ayuda de fa instrucción ¡F¡THEN t es posible reducir la longitud del programa. El 
mismo huele de cálculo se ejecutara en tres ocasiones, una para cada artículo. Al salir del 
ciclo, el programa sumará los importes parciales. 



40 INPUT "PRECIO DEL ARTICULO"; P 
50 LET N=C*P 

60 PRINT "CANTIDAD A PAGAR"; N 

70T=T=N 

80 LET 1=1+1 

90 IF f<3 THEN GOTO 30 
100 PRINT "LA CANTIDAD TOTAL A PAGAR 

ES;"; "PESETAS" 
110 END 

A todas luces, el nuevo programa mejora 
al anterior En primer lugar ahorra tiempo 
al programador a la hora de confeccionarlo 
V, por otra parte, el programa resulta bas- 
tante más versátil. Con un mínimo es- 
fuerzo es posible acondicionar el pro- 
grama para que sea capaz de totalizar la 
adquisición de cualquier número de pro- 
ductos distintos. Para ello, sólo hay que 
definir cuántas veces debe repetirse el 
bucle de cálculo. 

El número de veces que hay que repetir la 
rutina comprendida entre las líneas 30 y 
70 es controlable actuando en distintos 
puntos del programa: modificando el valor 
inicial de I (línea 20), alterando su valor 
final (línea 90), o incluso variando el incre- 
mento que experimenta la variable I en 
cada nueva ejecución de la rutina (lí- 
nea 80), 

Este ha sido un ejemplo ilustrativo de la 
ventaja que supone el empleo de instruc- 
ciones de control a la hora de realizar ta- 
reas repetitivas. No obstante, las posibili- 
dades de esta técnica no se reducen a lo 
expuesto. El ejemplo siguiente revela con 
mayor elocuencia las ventajas que aporta 
este método, aplicándolo a un programa 
capaz de obtener una lista de los números 
pares, desde el 0 al 100; 



10 LET C=0 
20 PRINT 1*2 

30 1=1+1 

40 IF I 50 THEN GOTO 20 
50 END 




En esta ocasión, la variable que se va in- 
crementando, y que a partir de ahora lla- 
maremos variable contadora, interviene 
directamente en los cálculos. Esta posibi- 
lidad ofrece ventajas muy interesantes en 
determinados casos. 
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LA ESTRUCTURA FOR/NEXT 



Se observa pues que las tareas rutinarias 
pueden ejecutarse cómodamente en el 
seno de bucfes. Estos consisten, sencilla- 
mente, en un bloque de instrucciones que 
se ejecutan una y otra vez, hasta que se 
cumple una determinada condición. 
La estructura más sencilla para la ejecu- 
ción de bucfes, y a su vez la más utilizada, 
es la FOR/NEXT. Esta queda definida en la 



figura adjunta, en la que aparecen un dia- 
grama de flujo representativo de su actua- 
ción. 

La instrucción o instrucciones que compo- 
nen la referida estructura FOR/NEXT de- 
ben contemplar cuatro elementos esen- 
ciales: 

— Delimitación de los extremos del bu- 
cle; hay que precisar el principio y final del 
mismo. 

— Indicación de los valores inicial y final 
de la variable que se utilizará como con- 
tador. 

— Definición del incremento o f de forma 
más general, de la variación que ha de 
experimentar le variable contadora con 
cada nueva ejecución de! bucle. 



— indicación de Ja variable que va a utili- 
zarse como contador. 
En el BASIC, todo ello queda plasmado 
dentro de una estructura formada por dos 
instrucciones: FOR y NEXT. 
En el argumento de la instrucción FOR 
hay que especificar cuál será la variable 
contadora, indicar el valor inicial y final de 
la misma (TO) y, además, precisar el incre- 
mento que experimentará dicha variable 
(STEP) en cada nueva ejecución del bucle. 
Hay que tener en cuenta que Ja variación 
que debe afectar a la variable contadora al 
completar cada ciclo puede ser incluso 
negativa. 

El formato generaJ de la instrucción FOR 
es el siguiente: 



Bucles 
anidados 



Los bucles anidados constituyen una 
técnica de programación que consiste en 
introducir bucles FOR/NEXT dentro de 
otros bucles de la misma naturaleza. Este 
es un método muy frecuentemente 
utilizado en las tareas de programación. 
Su puesta en práctica exige adoptar una 
precaución básica: los bucles deben 
"anidarse" de tal forma que cada uno de 
eJIos esté completamente incluido dentro 
del otro. A su vez, dos bucles, uno 
anidado dentro del otro H no pueden 
compartir la misma variable contadora, 
sino que ésta ha de ser distinta. 
El programa adjunto ilustra la actuación 
de un bucle anidado. 
Las instrucciones 20, 30 y 40 constituyen 
un bucle FOR/NEXT anidado dentro de 
otro bucle exterior, este último delimitado 
por las líneas 10 y 50. El bucle externo 



FOR 1=1 TON 

FOR J = 1 TO N 

FOR K = l TO N 
NEXT K 



NEXT J 

FOR L - 1 TO L 



10 FOR 1 = 1 T0 3 
20 FOR J=1 TO 2 
30 PRJNT U 
40 NEXT J 
50 NEXT I 
60 ENO 



BUN 
1 

1 

2 
2 
3 
3 




FOR I = 1 TO N 
FOR J ~ 1 TO N 

NEXT J 

FOR J = 1 TO L 



NEXT L 
NEXT 1 

Ejemplos de atildamiento correcto de estructuras tORjNEXT. 



NEXT 



utiliza la variable I como contador, 
mientras que el bucle anidado o interior 
emplea al respecto la variable J. 
La instrucción 30 (PRINT I, J} permite 
observar cómo discurre la ejecución del 
programa. Para cada valor de la variable 
contadora I (bucle exterior), se ejecutan 
todos los posibles ciclos del bucle anidado 
ípara J=1 y para J=2), Ello se debe a que 
el retomo del bucle extemo (NEXT J) sólo 
se produce una vez que se ha salido del 



FOR U1T0N 

p FORJ=170N! 

NEXT I 
I 

FOR 1-1 TON 

L NEXT J 
NEXT I 



r FOR ] -- 1 TO N 



FGRMÍQN 



L NEXT 1 



NEXT I 



Dos ejemplos de atildamiento incorrecto 
de hueles FORlNEXT. 



bucle interior y fa ejecución rebasa la 
instrucción 40. 

Algunos dialectos BASIC permiten cerrar 
los bucles anidados por medio de una 
sola instrucción NEXT, conteniendo ésta a 
todas las variables contadoras, ordenadas 
y separadas por comas. 
En el ejemplo anterior, la instrucción de la 
línea 40 quedaría, en tal caso, de la 
siguiente forma: 

40 NEXT JJ 

Hay que tener en cuenta, no obstante, 
que esta posibilidad no es compartida por 
todos los dialectos BASfC; de ahí que, en 
principio, sea oportuno recurrir b\ método 
más general de cerrar cada bucle con una 
instrucción NEXT específica. 
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FOR/NEXT 




Ejecuta el bucle encerrado entre ambas instrucciones tantas veces como sea necesario: 
hasta que la variabíe contadora alcance el valor de la expresión 2, partiendo el valor inicial 
establecido por la expresión 1 y en incrementos sucesivos dados por la expresión 3, 

Formato: FOR <variab!e> = <expr. 1 > TO <expr.2> STEP <expr,3> 

NEXT <variable> 
Ejemplos: FOR 1=1 TO 5 STEP 1.5 

NEXT 1 

FOR K=A TO B STEP -Z 
NEXT K 






FOR 



NEXT 



CONTADOR = VALOR INICIAL 



BLOQUE de INSTRUCCIONES 
QUE COMPONEN 
EL BUCLE 



CONTAI 



OR * 1 



La estructura de control FOR f NEXT facilita 
la programación de tareas repetitivas. En la 
primera línea de la mencionada estructura 
i FORfTOfSTEP) se definen los valores inicial 
y final, además del incremento^ de la 
variable que contabilizará los recorridos a 
través del bucle, A su vez. la instrucción 
NEXT pondrá fin al conjunto de 
instrucciones que constituyen el bucle 
definido, devolviendo el control a la línea 
FORlTOlSTEP. 




FOR <variable>=<valor iniciaf>TO <va- 
lor final > [STEP <¡ncremento>] 

De todos los elementos citados al princi- 
pio, sólo queda por concretar el que se 
refiere a la delimitación del bucle. Ello se 
consigue fácilmente colocando una ins- 
trucción NEXT al final del bloque de ins- 
trucciones que constituyen el bucle. Su 
formato es tan simple como el que sigue: 

NEXT <variable> 

Por supuesto, la variable ha de coincidir 
con la utilizada como variable contadora 
en el argumento de 3a correspondiente 
instrucción FOR. 
Veamos un sencillo ejemplo: 



10 FOR 1=1 TO 3 
20 PRINT I 
30 N EXT I 
40 PRINT "TU- 
SO EN D 





Al ejecutar el programa se observa que el 
bucle, constituido en este caso por una 
única instrucción (20 PRINT I), es ejecu- 
tado tres veces. 

Tras recibir la orden RUN, se ejecuta por 
primera vez la instrucción 10, Esta dicta al 
ordenador que debe repetir la ejecución 
del bucle mientras que el valor de la varia- 
ble contadora I (inicial izada a 1) no exceda 
def límite 3. En este caso, al omitir la indi- 
cación del incremento sucesivo que debe 
afectar a I (zona STEP), la máquina inter- 
pretará que debe incrementarla en una 
unidad tras cada recorrido del bucle. 



Diagrama de flujo representativo del 
funcionamiento de una estructura de bucle 
del tipo FORÍNEXT. 
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En definitiva, el bucle comenzará a ejecu- 
tarse por primera vez para un valor de la 
variable contadora igual al valor inicial 



(1 = 1). Tras ejecutar la instrucción 20, se 
llegará a la que pone fin al bucle: NEXT I. 
En ese preciso instante, la variable conta- 



dora se incrementará en una unidad y el 
ordenador regresará a la instrucción FOR 
(instrucción 10). En ella, comprobará el 



Simulación de la estructura ON/GOTO 



La disparidad de los dialectos del lenguaje 
BASIC que equipan los distintos 
ordenadores se traduce en muy variados 
inconvenientes. Uno de ellos es la posible 
ausencia de la instrucción GN/GOTO, lo 
que, en principio, parece obligar al 
programador a olvidarse de esta eficaz 
herramienta para la toma de decisiones 
de múltiple alternativa. Aun cuando éste 
sea el caso, no hay por qué renunciar a 
esta útil estructura de control, ya que es 
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Diagrama de flujo del programa 
"Pronósticos" , construido en base a una 
estructura ONÍGOTO. 

posible simularla por medio de otras 
instrucciones BASIC más habituales. 
La descripción va a partir del siguiente 
ejemplo: 

100 X=(RND*31+1 
110 0N X GOTO 200 r 300,400 
200 PRINT "PRONOSTICO: 1" 
210 GOTO 600 

300 PR1NT "PRONOSTICO: X" 
310 GOTO 600 

400 PRINT "PRONOSTICO: 2" 

600 "¡SUERTE Y A POR LOS CATORCE!" 

700 END 

Se trata de una zona de programa BASIC 
que incluye una toma de decisión 
múltiple, y cuyo correspondiente diagrama 



de flujo aparece en la figura adjunta. El 
cometido de este simple programa es la 
emisión de pronósticos para rellenar 
quinielas al azar. 

La instrucción 1 00 incluye ta función 
RND: una herramienta del vocabulario 
BASIC adecuada para ia generación de 
números aleatorios y cuyo estudio se 
acometerá en un próximo capítulo de la 
obra. Por el momento, basta con saber 
que al ejecutar la referida instrucción, la 
variable X adoptará un valor comprendido 
entre 1 y 3, Este valor será el que utilizará 
la instrucción ON/GOTO para bifurcar 
hacia las líneas 200, 300 ó 400 y 
presentar fos pronósticos 1. X ó 2. 
respectivamente. 

La escritura de esta rutina omitiendo la 
instrucción ON/GOTO no plantea 
excesivos problemas. Et método más 
inmediato es recurrir al empíec z% 
sucesivas decisiones simples del tipo 
IF/THEN. Desde luego, el programa será 
más extenso, pero mantendrá su eficacia. 
Aquí está una posible solución que 
consiste, sencillamente, en sustituir la 
línea 110 del programa inicial por las tres 
siguientes: 

110 IF X=1 THEN GOTO 200 
120 IF X-2 THEN GOTO 300 
130 IF X=3 THEN GOTO 400 

Al observar el funcionamiento de la 
primera instrucción del programa, salta a 
la vista que el valor de X siempre va a ser 
1, 2 ó 3. De ahí que sea suficiente con 
detectar dos de los posibles valores, por 
ejemplo 2 y 3. Naturalmente, de no 
adoptar el valor 2 ó 3, X será igual a 1; en 
consecuencia, puede eliminarse la 
comparación con 1 , de tal forma que su 
ejecución ocurra en el caso de no resultar 
positivas las otras dos detecciones. 
Una vez eliminada la comparación de X 
con 1 — asumiendo que X no va a 
exceder en ningún caso del margen de 
valores esperado — , ef programa quedará 
como sigue: 

100X={RND*3)+1 
110 IF X=Z THEN GOTO 300 
120 IF X=3 THEN GOTO 400 
200 PRINT "PRONOSTICO: 1" 
210 GOTO 600 

300 PRINT "PRONOSTICO: X" 
3T0 GOTO 600 

400 PRINT "PRONOSTICO: 2" 



600 PRfNT "j SUERTE Y A POR LOS CATORCE!" 
700 END 

Su desarrollo es ilustrado por el 
correspondiente diagrama de flujo. 
Algunos ordenadores admiten una 
segunda alternativa. Para ello, han de 
cumplirse dos condiciones. En primer lugar, 
su traductor BASIC ha de permitir el empleo 
de variables y expresiones en el argumento 
de la instrucción GOTO; por otra parte, debe 
ser posible encontrar una relación 
matemática entre las diferentes lineas a 
ías que se desea bifurcar, en función de 
los valores que tome la variable o 
expresión a evaluar 
En el ejemplo propuesto, la línea 110 
— ocupada por la instrucción ON/GOTO — 
podría reemplazarse por la siguiente: 

110 GOTO [xnwi+toü 

Tal como se observa, los posibles valores 
de X {1 r 2 ó 3) r provocarán el safto a las 




Diagrama de flujo del programa 
propuesto, una vez sustituida ta 
instrucción ONfGOTO por dos tomas de 
decisión del tipo IFjTHEN. 

líneas 200, 300 y 400, respectivamente. 
Esta es una solución bastante más 
cómoda; sin embargo, hay que tener en 
cuenta que no siempre es posible 
aplicarla. 
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NEXT I 








Aplicando la instrucción FOR/NEXT al 
ejemplo inicial, se reducirá la amplitud del 
programa adecuado para el cálculo del 
importe total de una compra. Un mismo 
bucle de programa se ocupará de evaluar el 
importe de cada articulo de acuerdo a la 
cantidad adquirida en cada caso. 



omitirse (cosa que ocurre en el ejemplo 
propuesto). En ta! caso, el ordenador 
asume que el valor del incremento es la 
unidad. 

El valor del incremento puede ser cual- 
quiera, incluso negativo, con lo que se 
convertiría en un decremento del valor de 
la variable contadora. En este último caso, 
la cifra colocada como valor inicial ha de 
ser mayor que 3a correspondiente al valor 
final, 

A continuación aparecen dos ejemplos 
que definen distintos incrementos para la 
variable contadora. 

El primer programa establece un bucle 
controlado por la variable X, El bucle debe 
repetirse sucesivamente hasta que X 
adopte un valor superior a 1.5, teniendo 
en cuenta que tras completar cada ciclo, 
el valor de X se incrementará en 0. 1 unida- 
des. (Tal como es habitual en BASIC, la 
coma decimal se sustituye por el punto de 
acuerdo a la nomenclatura inglesa.) 




El lenguaje 
BASIC incorpora 
una herramienta 
idónea para 
programar tomas 
de decisiones de 
múltiple 

alternativa: ésta 
es la instrucción 
O N ¡GOTO. 



valor actual de I, para verificar si supera o 
no al valor final establecido (TO 3). 
Tras esta operación caben dos alternati- 
vas. Si el nuevo valor de la variable I es 
inferior al valor final precisado, se repite 
de nuevo Ja ejecución del bucle. Por el 
contrario, si fa variable contadora supera el 
. = z r final no se repetirá fa ejecución del 
bucle, sino que el ordenador pasará a eje- 
cutar la instrucción que sigue al NEXT que 
pone fin a la estructura cíclica. 
Cabe recordar que la zona STEP puede 




La ejecución revela que el bucle se reco- 
rre en seis ocasiones, mostrando en cada 
caso el correspondiente valor de la varía- 
ble X. 



10 FOR X=1 TO 1.5 STEP 0.1 

20 PRINT X; 

30 NEXT X 

40ENO 

RUN 

1 1.1 12 U 14 1.5 



En el segundo ejemplo, la variable conta- 
dora I toma el valor inicial 5 y en cada ciclo 
sucesivo irá decre mentándose en una uni- 
dad (STEP -1), hasta que su valor sea 
inferior a 2 (TO 2). El bucle incluye, senci- 
llamente, una instrucción PRINT que pre- 
senta en la pantalla los sucesivos valores 
de I multiplicados por 4. 



10 FOR I-5 TO 2 STEP 

20 PRINT I 4 

30 NEXT I 

40 EN D 

RUN 

20 

16 

12 

4 



No terminan aquí las posibilidades de la 
estructura FOR/NEXT, A lo largo de la 
obra se irá observando su versatilidad en 
fa programación de estructuras cíclicas de 
muy diverso tipo. 

Una de las opciones que otorga aún ma- 
yor flexibilidad a esta estructura, deriva de 



Dependiendo del resultado de la expresión (1, 2, 3..,} se produciré un salto a la línea cuyo 
número aparezca en la posición correspondiente (primera, segunda, tercera...) dentro de la 
lista de números de línea que sigue a GOTO, 

Formato: ON <expresión> GOTO < lista de números de línea > 

Ejemplos: ON A GOTO 100, 200 r 230, 400 r 160 
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la posibilidad de sustituir alguno de los 
oa ra metros (valor inicial, valor final o incre- 
mento), o todos ellos, por una variable; el 
programa siguiente constituye un ejemplo 
elemental aunque ilustrativo de tal posibi- 
lidad: 

5 LET A=2 
10 INPUTB 
20 FOR l=A TO B 
30 PRINT I 
40 NEXTI 
50 END 

Tanto el valor inicial como el final lo apor- 
tan variables (A y B, respectivamente), 
cuyo valor puede asignarse en cualquier 
zona previa del programa. 



LA INSTRUCCION 0N/G0T0 



En ciertos casos, es necesario plantear 
decisiones con más de una alternativa. En 
a vida real H ello no plantea dificultades; 
sin embargo, en un ordenador la cosa no 
es tan fácil. Suponga, por ejemplo, que 
disponemos de un menú con varias opcio- 
nes: 

1, Imprimir las máximas puntuaciones. 

2, Realizar una demostración. 

3, Empezar el juego. 

^ n menú de tres opciones que conduce a 
: r es procesos distintos. Según el número 
de la opción elegida, el ordenador habrá 
de ejecutar una serie de operaciones, muy 
distintas en cada caso. Uno de los pesi- 
óles métodos para programar esta toma 
de decisión en BASfC consiste, simple- 
mente, en encadenar sucesivas instruc- 
ciones IF/THEN; por ejemplo: 




on/goto 



TABLA DE CONVERSION 


ORDENADOR 


FORytMEXT 


ON/GOTO 


FOR <varíable>=<¡> 
TO <f> STEP <r> 


NEXT < variable > 


ON expresión 
GOTO <l¡Sta> 


APPLE II 
(APPLESOFT) 


FOR <variable>=<¡> 
TO <f> STEP <r> 


NEXT <varíable> 


ON <expres¡ón> 
GOTO <lista> 


APRICOT 
(M-BASIC) 


FDR <-vanable> = <i> 
TO <f> STEP <r> 


NEXT <variable> 


ON <expres¡ón> 
GOTO <lísta> 


ATAR! 


FOR < variable > — <í> 
TO <f> STEP <r> 


WEXT <variable> 


ON <expresíón> 
GOTO <lista> 


CBM 64 


FOR <variable>=-<i> 
TO <f> STEP <r> 


NEXT < variable > 


ON <expresión> 
GOTO <lista> 


DRAGON 


FOR <vanable> = <i> 
TO <f> STEP <r> 


NEXT <variable> 


ON <expres¡6n> 
GOTO <lísta> 


EQUIPOS 
MSX 


FOR <variable> = <i> 
TO <f> STEP <r> 


NEXT <varíabíe> 


ON <expresión> 
GOTO <lisía> 


HP-150 


KJn <vananle>=<i> 
TO <f> STEP <r> 


NEXT <variable> 


ON <expresión> 
GOTO <lista> 


IBM PC 


rUH <variaDle>— <l> 
TO <f> STEP <r> 


NEXT <variabfe> 


ON <expresión> 
GOTO <lista> 


WTPF 


FOR <variable>— <i> 
TO <f> STEP <r> 


NEXT <variab[e> 


ON <expresión> 
GOTO <lísta> 


NCR DM-V 
(MS-BASIC) 


FOR <variable>=<i> 
TO <f> STEP <r> 


NEXT <variab[e> 


ON <expresión> 
GOTO <lista> 


NEW BRAIN 


rUn -- V& E ! d U 1 c _ — v^|^> 

TO <f> STEP <r> 


NEXT <variable> 


ON <expresión> 
GOTO <lista> 


ORIC 


FOR <variable>=<:i> 
TO <f> STEP <r> 


NEXT < varia ble > 


ON <expresíón> 
GOTO <lista> 


SHARP MZ-700 
(MZ-BASIC) 


FOR <variable> = <i> 
TO <f> STEP <r> 


NEXT < variable > 


ON <expresián> 
GOTO <lista> 


SINCLAIR OL 


FOR <variable>=<¡> 
TO <f> STEP <r> 


NEXT <variable> 


ON <expresión> 
GOTO <lista> 


SPECTRAVIDEO 


FOR <variable> = <¡> 
TO <f> STEP <r> 


NEXT -variable > 


ON < expresión > 
GOTO <l¡sta> 


ZX-SPECTRUM 


FOR <varrable>-<i> 
TO <f> STEP <r> 


NEXT <variable> 


ON <expresion> 
GOTO <lista> 



s) m> w 



< varia ble >: varia bie numérica. <i>; expresión que aporta el valor inicial. <f>: expresión que define eJ valor final. 
<r>: expresión que define el incremento. < lista >: lista de números de línea. 



FORMULACIONES DE LOS COMANDOS 

FOR <variable>: <i> TO <í> STEP <r>: define un bucle que se ejecutará repetidamente hasta que la variable 
alcance el valor de f, en sucesivos incrementos de valor r. NEXT <vahable>: cierra el bucle definido por medio de 
una instrucción FOR. ON < exprés i ón> GOTO <!¡sta> : transfiere la secuencia de ejecución a uno de los números 
de línea que figuran en la lista, en función del valor de la expresión. 



147 



Basic 




Funcionamiento de la instrucción 
ONfGOTO. El valor que adopte la 
variable X o, en general, la expresión 
que sigue a ON, determinará el 
número de línea al que debe bifurcar 
el programa. Los números de línea 
que pueden verse afectados son los 
que aparecen en la lista incluida en la 
zona GOTO. 



10 JNPUTA 

20 1F A-1 THEN GOTO 500 

30 ÍFA=2 TOEN GOTO 10OÜ 

40 IF A=3 TOEN GOTO 1500 

50 PRÍNT "ESA OPCION NO ESTA EN EL 

MENU" 
60 GOTO 10 



El bloque de instrucciones empieza cap- 
tando el número de la opción elegida a 
través de la instrucción INPUT A (línea 10). 
Acto seguido, las instrucciones 20, 30 y 
40 detectan cada una de las tres posibles 
alternativas, y derivan la secuencia de eje- 
cución hacia los subprogramas correspon- 
dientes a cada una de ellas. En efecto, se 
ha supuesto que ios respectivos subpro- 
gramas se encuentran situados a partir de 
las líneas 500, 1000 y 1500. 
El ejemplo termina con las instrucciones 
50 y 60. La primera de ellas presentará un 
mensaje al usuario en el caso de que se 
introduzca un número que no corres- 
ponda a una de las opciones permitidas; 
tras ello, y por efecto de la instrucción 
GOTO 10, el ordenador aguardará a que 
se introduzca de nuevo el número de la 
opción. 

De la eficacia de esta solución no cabe la 
menor duda. No obstante, ¿qué sucederá 
si el número de opciones deí menú se 
eleva a veinte o treinta? El programa 
puede prolongarse más y más, a base de 
ir colocando sucesivas instrucciones de 
tipo IF/THEN, y todo ello con el único 
objetivo de detectar la opción elegida y 
bifurcar la ejecución a la línea adecuada. 
En efecto, el método es eficaz, pero du- 



dosamente práctico cuando las alternati- 
vas son múltiples. Hay que buscar otro 
procedimiento más cómodo y rápido. 
Para programar este tipo de tomas de de- 
cisión de una forma más razonable, es 
necesario recurrir a estructuras lógicas 
más complejas. Estructuras que permitan 
seleccionar una entre varias opciones, de- 
pendiendo deJ valor que adopte una ex- 
presión a evaluar. 

El lenguaje BASIC posee una instrucción 
especializada en tal cometido; ésta es 
ON/GOTO, cuyo formato general es el si- 
guíente: 

ON <expresión> GOTO <lista de núme- 
ros de línea> 

Al utilizar la nueva instrucción, el pro- 
grama anterior adoptará un nuevo as- 
pecto: 



10 INPUT A 

20 0N A GOTO 500, 1000, 1500 

30 PRINT "ESA OPCION NO ESTA EN EL 

MENO" 
40 GOTO 10 



Sin lugar a dudas, el empleo de la instruc- 
ción ON/GOTO reduce ta amplitud del 
programa; especialmente si pensamos en 
un caso en el que la decisión esté sujeta a 
un elevado número de opciones. 
Las dos zonas que conforman a la nueva 
instrucción están perfectamente delimita- 
das. La primera de el!as la ocupa el co- 
mando ON y su argumento. Este contiene 



la expresión a evaluar, o sencillamente la 
variable cuyo valor condicionará 3a bifurca- 
ción o salto. 

El comando GOTO y su argumento, inte- 
grado por una serie de números de línea 
separados por comas, dan cuerpo a la se- 
gunda zona de la instrucción. La relación 
entre ambas es muy simple. Tras evaluar 
el resultado de la expresión que acom- 
paña a ON, el ordenador ejecutará un salto 
al número de línea que sigue a GOTO, 
cuya posición coincida con el valor ex- 
traído en la zona ON. Esto es; si el valor 
de la expresión es 1, el salto se producirá 
al primer número de línea; si es 2 al se- 
gundo; si su valor es 3 al tercero y así 
sucesivamente. 

En el programa ejemplo, cuando se elija Ja 
opción 1 —tal será el valor de la variable A 
que ocupa la zona ON — r el salto condu- 
cirá a la línea 500; sí se elije la opción 2, el 
salto llevará a la línea 1000; mientras que 
si la opción seleccionada es la 3, el pro- 
grama bifurcará la línea 1500. 
En definitiva, la elección se realiza a partir 
del valor de la expresión localizada en la 
zona ON, Si fuera necesario, el ordenador 
redondeará el valor del resultado al nú- 
mero entero más próximo, para que de 
esta forma quede precisado el orden del 
número de línea al que debe producirse el 
salto. 

También puede ocurrir que el valor de la 
expresión sea cero, o mayor que el nú- 
mero de elementos en la lista; en tales 
circunstancias no se producirá salto al- 
guno, sino que se ejecutará la instrucción 
siguiente a ON/GOTO. 
En otro orden, puede suceder que el valor 
de la expresión sea negativo superior a 
255; ambas situaciones harán que eí or- 
denador presente un mensaje de error en 
la pantalfa. 
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Logo (7) # 

TURTLE GRAPHICS: 
procedimientos con la tortuga 



j^Jt entro del apartado precedente 
| dedicado al J Turtle graphics" 
|| J | (Logo 3), se presentaron los 
mSSSr fundamentos del tratamiento 
de gráficos con el LOGO. Asimismo, en 
otro punto de la obra se detalló el con- 
cepto y uso de los procedimientos. Este 
capítulo va a combinar ambos temas, tras- 
ladando fas posibilidades que ofrecen los 
procedimientos al terreno de la confec- 
ción de dibujos con la tortuga. Se crearán 
procedimientos capaces de trazar gráficos 
y se verán las enormes posibilidades que 
éstos aportan a la confección de gráficos. 



PROCEDIMIENTOS CON 
LA TORTUGA 



Uno de los ejemplos incluidos en la pre- 
sentación del "Turtle graphics" fue la se- 
cuencia de órdenes adecuadas para trazar 
una línea en la zona superior de la pantalla, 
devolviendo a la tortuga, a continuación, a 
su posición original. El referido conjunto 
de órdenes puede integrarse dentro de un 
procedimiento, sin más que apelar al me- 
lado de definición ya estudiado; por ejem- 
plo: 



"~ ©1 — - 

© 




? CUADRADO 1 

L ? J 



Dibujo creado en la pantalla por medio del 
procedimiento CUADRADO I. Los 
vértices numerados corresponden a ¡os 
pantos que alcanza la tortuga tras ejecutar 
cada una de las sucesivas órdenes 
FORWARD 50. 



TO LINEA 
CS 

PENUP 
FORWARD 50 
RIGHT 90 
PENDOWN 
FORWARD 50 
PENUP 
HOME 
END 

Al integrar la secuencia de órdenes dentro 
de un procedimiento, se evita Ja necesi- 
dad de teclear de nuevo las mismas órde- 
nes cada vez que desee realizarse la 
misma acción. 

Todas las posibilidades de la creación de 
gráficos por medio de la tortuga pueden 
incluirse en procedimientos. A continua- 
ción, se describen algunos procedimien- 
tos con la tortuga que pueden resultar 
útiles a la hora de trazar dibujos más com- 
plejos. 

El primero de ellos, cuyo nombre es CUA- 
DRADO 1, es capaz de dibujar un cua- 
drado de 50 posiciones de lado. Tras con- 
feccionar el dibujo, la tortuga queda em- 
plazada en su posición de origen, tal como 
muestra la correspondiente pantalla. 

TO CUADRADO 1 
FORWARD 50 
RIGHT 90 



? TRIANGULO 1 

^ 




Eí procedimiento TRIANGULO 1 instruye a 
la tortuga para que trace en la pantalla el 
dibujo ilustrado. La ejecución de cada una 
de las tres órdenes FORWARD que en él 
intervienen conduce a ta tortuga a los 
distintos vértices del triángulo. 



FORWARD 50 
RIGHT 90 
FORWARD 50 
RIGHT 90 
FORWARD 50 
RIGHT 90 
END 

Un nuevo ejemplo lo aporta el procedi- 
miento que sigue {TRIANGUL0 1); su eje- 
cución dibuja un triángulo cuyo lado es de 
50 posiciones. 

T0 TRIANGULO! 
FORWARD 50 
RIGHT 120 
FORWARD 50 
RIGHT 120 
FORWARD 50 
RIGHT 120 
END 

De nuevo, en este segundo ejemplo, una 
vez realizado el dibujo, la tortuga queda en 
la posición de partida. Cabe notar que la 
suma de los ángulos girados es de 360 
grados (una vuelta completa), de ahí que 
el retorno de la tortuga a [a posición de 
origen, y con la orientación adecuada, sea 
directo. 

Ahora, es posible utilizar los dos procedi- 
mientos elementales definidos para crear 
figuras más complicadas. Un ejemplo lo 
constituye el procedimiento BANDERIN 1 
que hace uso de TRIANGULO! para dibu- 
jar un banderín con mástil. 



TO BANDERIN1 
FORWARD 30 
TRIANGUL01 
END 
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LOGO 




LIBRO 



6 

LOGO 




La técnica de los procedimientos LOGO es íntegramente aplicable al método ' " Turtle 
Graphics". Las secuencias de órdenes de dibujo pueden adoptar la forma de procedimientos, 
con o sin parámetros. 



El cuadro adjunto contiene tres nuevos 
ejemplos de procedimientos de dibujo 
más evolucionados (CASA, ROMBO y 
MOLINO), que hacen uso de los ya defini- 
dos: CUADRADOI y TRIANGULOI . 
Estas son algunas posibilidades que 
brinda la aplicación de ios procedimientos 
LOGO al método "Turtle graphics". Por 
supuesto, la versatilidad de ios procedi- 
mientos con parámetros también es tras- 
ladable al caso de la tortuga. Muestra de 
ello van a constituirla los ejemplos de los 
próximos apartados, 

PROCEDIMIENTOS A MEDIDA 



Una vez creados los procedimientos CUA- 
DRADOI y TRIANGULOI quedan defini- 



dos ambos dibujos en el campo de tra- 
bajo. Para utilizarlos, no hay más que lla- 
mar al respectivo procedimiento utili- 
zando su nombre. Las referidas figuras 
pueden trasladarse a cualquier posición 
de la pantalla. Para ello basta con colocar 
la tortuga en la posición y orientación ade- 
cuadas. E incluso puede alterarse el ta- 
maño de los dibujos. Esto último exige 
algunos retoques en el procedimiento 
para que sea posible introducir la longitud 
de un lado. Ta! valor puede introducirse 
como parámetro de entrada al procedi- 
miento. Veamos cuál es el aspecto de 
ambos ejemplos una vez convertidos en 
procedimientos con un parámetro de en- 
trada. 



10 CUADRADO :L 
FORWARD :L 




CASA 

TO CASA RIGHT 30 
CUADRADO] TRIANGULO! 
FORWARD 50 END 



ROMBO 

TO ROMBO PX 

RIGHT 30 TRIANGULOI 

TRIANGULO! PÉNDQWN 

RIGHT 60 END 



La aplicación de la técnica de los procedimientos 
LOGO ai dibujo con la tortuga, permite construir 
procedimientos gráficos, cada vez más complejos, al 
asociar otros procedimientos elementales. Las pantallas 
ilustran la ejecución de tres procedimientos en cuya 
definición intervienen otros más primitivos 
(CUADRADO I y TRIANGULO I) definidos con 
anterioridad. 



MOLINO 




TO MOLINO 


TRIANGULOI 


TRIANGULOI 


LEFT 45 


LEFT 45 


TRIANGULOI 


TRIANGULOI 


LEFT 45 


LEFT 45 


TRIANGULOI 


TRIANGULOI 


LEFT 45 


LEFT 45 


TRIANGULOI 


TRIANGULOI 


LEFT 45 


LEFT 45 


END 



RI6HT 90 
FORWARD 
RIGHT 90 
FORWARD 
RIGHT 90 
FORWARD 
RIGHT 90 
EMD 



En el primer caso (dibujo de un cuadrado), 
la diferencia aparece en el parámetro L 
Su cometido es definir la magnitud del 
lado del cuadrado, de ahí que su valor 
acompañe a las cuatro órdenes FOR- 
WARD, 

Análogamente, puede definirse un proce- 
dimiento capaz de dibujar un triángulo 
cuyo lado lo precisará el parámetro de en- 
trada L. 



TO TRIANGULOS 
FORWARD :L 
RIGHT 120 
FORWARD :L 
RIGHT 120 
FORWARD :L 
RIGHT 120 
END 



En definitiva, los dos nuevos procedimien- 
tos permiten definir el tamaño de la figura 
a través del valor o parámetro que se 
agrega como entrada al procedimiento. El 
siguiente ejemplo, CUADROS, utiliza esta 
posibilidad para dibujar en la pantalla un 
conjunto de cuadrados de distinto lado. 
CUADROS no es más que un procedí- 
miento evolucionado, creado a partir de la 
repetición del procedimiento con paráme- 
tro CUADRADO :L 



TO CUADROS 
CUADRADO 20 
CUADRADO 40 
CUADRADO 60 
CUADRADO 80 
CUADRADO 100 
END 



De la misma forma se pueden definir pro- 
cedimíentos más genéricos. Por ejemplo, 
uno que dibuje polígonos regulares dando 
el número de lados y su longitud; tal es el 
caso del procedimiento POLIGONO defi- 
nido a continuación; 
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INICIA 
TO INICIA 

es 

PENUP 

LEFT 9 0 
FORWARD 100 
RIGHT90 
PENDOWN 
EJSJD 




TRANS 

TO TRANS : 
PENUP 
RIGHT 90 
FORWARD : 
LEFT 90 
PENDQWM 
END 





SUBE 

TO SUBE ;L 
PENUP 
FORWARD :L 
PENDOWN 
END 



BAJA 

TO BAJA :L 
PENUP 
BACK :L 
PENDOWN 
END 




BANDERÍN 

TO BANDERIN :L 
FORWARD :L 
TRIANGULO XJ1 
BACK :L 
END 



Cinco procedimientos elementales o li de utilidad", adecuados para ía creación 
de superprocedimíen tos gráficos. 



TO POLIGONO :N :L 
REPEAT :N [FORWARD 
END 



L RIGHT 360/:N] 



Su definición, extremadamente com- 
pacta, adopta el aspecto de procedi- 
miento con dos parámetros de entrada: N 
(número de lados del polígono) y L (longi- 
tud del lado). Un aspecto a señalar es la 
presencia dentro del procedimiento del 
comando REPEAT Su estudio detallado 
tendrá lugar en el capítulo dedicado a "bu- 
cles"; por el momento basta con saber 
que ordenará la repetición de las acciones 
encerradas entre corchetes tantas veces 
como indique el parámetro N. 
Si el número de lados especificado es 3 ó 
4, POLIGONO se comporta como los pro- 
cedimientos TRIANGULO o CUADRADO, 
respectivamente, 

COLECCION DE EJEMPLOS 



Para trasladar al terreno práctico los cono- 
cimientos adquiridos hasta el momento, 
vamos a poner a trabajar a la disciplinada 
Tortuga. 



La siguiente colección de ejemplos hará 
uso de los procedimientos elementales o 
de utilidad INICIA, TRANS, SUBE, BAJA y 
BANDERIN que se detallan en el cuadro 
correspondiente. Los referidos procedi- 
mientos de utilidad entrarán a formar 
parte de la definición de superprocedi- 
mientos más evolucionados, capaces de 
"instruir" a la tortuga para que trace en la 
pantalla dibujos más elaborados. 
Al utilizar Eos cinco procedimientos ele- 
mentales, definidos en el cuadro adjunto, 
nuestro simpático dibujante — la tortu- 
ga — debe estar orientada en sentido 
vertical y "mirando" hacia el borde supe- 
rior de la pantalla. 

Con esta precaución, la actuación de ios 
referidos procedimientos elementales 
será la que sigue: 

INICIA: desplaza a la tortuga a la izquierda 
de la pantalla, levantando la tiza para que 
no deje trazo al trasladar su origen. 
TRANS; traslada a la tortuga tantas posi- 
ciones a la derecha como indique el valor 
del parámetro L; de nuevo, sin dejar trazo 
alguno en la pantalla. 
SUBE, BAJA: ambos procedimientos per- 
miten alterar la posición vertical de la tor- 



tuga: hacia arriba o hada abajo, respecti- 
vamente. 

BANDERIN: dibuja un banderín del ta- 
maño especificado. 

Con estos procedimientos elementales, 
van a dibujarse a continuación varias esce- 
nas, sencillas aunque plenamente ilustra- 
tivas de fas posibilidades que otorgan los 
procedimientos al trazado de gráficos en 
pantalla. Desde fuego, el usuario puede 
crear sus propios dibujos utilizando y alte- 
rando alguno de los siguientes ejemplos. 
El primero de los ejemplos (PLANTAR}, 
hace uso de los procedimientos SUBE, 
BANDERIN y BAJA para dibujar un bande- 
rín en la zona superior de la pantalla. 



TO PLANTAR :L 
SUBE :L 

BANDERIN 100-(:L/3) 

BAJA :L 

END 



100 



TO CUADROS 

CUADRADO 20 
CUADRADO 40 
CUADRADO 60 
CUADRADO 80 
CUADRADO 100 
END 



6 



80 



60 



40 



20 



Ejecución del 
superprocedimiento 
CUADROS. Dentro 
de su definición 
Interviene 
repetidamente un 
procedimiento 
(CUADRADO) cuyo 
parámetro de 
entrada coincide con 
ei lado del cuadrado 
a dibujar. 
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A su vez, CAMPOI, es un procedimiento 
evolucionado que recurre a los procedi- 
mientos elementales INICIA, BANDERIN, 
TRANS y PLANTAR para dibujar en la pan- 
talla una escena con cinco banderines: 

TO CAMPO! 
INICIA 

BANDERIN BC 
TRANS 50 
PLANTAR 60 
TRANS 40 
PLANTAR 20 
TRANS 60 
PLANTAR 35 
TRANS 40 
PLANTAR 53 
END 

A continuación, se desarrollan nuevos 
ejemplos a partir de POLIGONO, El proce- 
dimiento CIRCUNFERENCIA particulariza 
el procedimiento POLIGONO, definido en 
el apartado anterior, para un número 
grande de lados (30) y calcula su longitud 
partiendo del radio. Este procedimiento 
se utiliza dentro de ARBOL para dibujar la 
copa. 



TO ARBOL :L 
FORWARD :L 
LEFT 90 

CIRCUNFERENCIA 
RIGHT 90 
BACK :L 
END 



1*3/4 




r r rrr 



? CAMPO 1 

9 



Resultado de la 
ejecución de dos 
procedimientos de 
dibujo definidos en 
el texto: PLANTAR 
y CAMPO L 



? BOSQUE 
9 



? PAISAJE 
9 



? PUEBLO 

9 



representación gráfica que muestra la co- 
rrespondiente pantalla. 

T0 BOSQUE 
INICIA 
PON 50 
TRANS 40 
PON 20 
TRANS 40 
PON 35 
TRANS 40 
PON 17 
TRANS 40 
PON 65 
TRANS 40 
PON 44 
END 



Asociando los procedimientos BOSQUE, 
BAJA y CASA es posible ya eJ dibujo de 
un paisaje en el que aparezcan árboles e 
incluso una casa. 



TO PAISAJE 

BOSQUE 

BAJA 30 

CASA 

PENUP 

HOME 

PENDOWN 

END 




TO CIRCUNFERENCIA :R 
POLIGONO 30{(:R*6.28}/30) 
END 

A su vez H BOSQUE se apoya en el proce- 
dimiento ARBOL, situando cada elemento 
en la pantalla con la ayuda del procedi- 
miento PON. 

TO PON :L 
SUBE :L 

ARBOL [100 : L)/3 
BAJA :L 
END 

Este último es similar a PLANTAR, aun- 
que recurriendo a ARBOL en lugar de a 
BANDERIN. Su empleo repetido dentro 
del procedimiento BOSQUE da lugar a la 



Cada vez los dibujos pueden ser más y más 
complejos, al irse enriqueciendo con la 
incorporación de procedimientos defini- 
dos a base de otros más elementales. 
Por ejemplo, introduciendo algunas va- 
riantes al procedimiento INICIA puede de- 
finirse un nuevo procedimiento que deno- 
minaremos INI; esta vez, el desplaza- 
miento de la tortuga no borrará eJ conte- 
nido de la pantalla. 

ID INI 
PENUP 
HOME 
LEFT 90 
FORWARD 120 
RIGHT 90 
PENDOWN 
END 



La evolución puede seguir en sucesivas 
etapas. Por ejemplo, introduciendo el pro- 
cedimiento anterior (PAISAJE) dentro de 
un nuevo s upe rproced i miento capaz de 
plasmar en la pantalla el dibujo de un pue- 
blo de ¡a mano de la tortuga LOGO. 

TO PUEBLO 
PAISAJE 
RAJA 40 
CASA 
INI 

BAJA 50 

CASA 

PENUP 

HDME 

PENDOWN 

END 
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Estructura de la memoria 

¿Cómo reside el CP/M en 
la memoria del ordenador? 



L a memoria de un ordenador es 
el soporte en el que se alma- 
cenan los programas y datos: 
o io que es lo mismo, el lugar 
donde residen todos los elementos soft- 
ware necesarios para el funcionamiento 
de la máquina: el sistema operativo, los 
programas de aplicación y los datos nece- 
sarios para la ejecución de los programas. 
Esta es una definición genérica y aplicable 
a cualquier ordenador. 
En ta práctica, una de las diferencias que 
se manifiestan entre los distintos ordena- 
dores reside en la forma en la que cada 
uno de ellos distribuye los elementos soft- 
ware en su memoria. Elío se debe, bási- 
camente, a ¡os condicionantes que im- 
pone el propio sistema operativo que rige 
Ja actividad del ordenador. 
La memoria de un ordenador puede divi- 
dirse en dos grandes apartados, 

* Memoria primaria 

También denominada memoria central o 
residente. Está alojada en el interior de ¡a 
máquina y consta de un conjunto de cir- 
cuitos electrónicos capaces de almacenar 
la información. Por lo demás, constituye el 



MEMORIA 
EXTERNA 



MEMORIA 
INTERNA 



a® 

\ DISCO DISCO 
¡ FLEXIBLE R| G ¡ D o 



La memoria del ordenador cabe dividiría en 
dos grandes apartados: memoria central, 
interna o residente en la unidad central y 
memoria externa o de masa . Esta última la 
aportan al sistema ios periféricos de 
almacenamiento conectados al mismo. 



soporte básico de la información almace- 
nada en el ordenador. 

* Memoria secundaria 
Está localizada fuera del ordenador y los 
dispositivos en los que se apoya entran 
dentro de la categoría de tos periféricos. El 
soporte de almacenamiento suele ser un 
disco magnético, ya sea de tipo flexible o 
rígido. Su presencia, en número y capaci- 
dad de almacenamiento, depende del mo- 
delo específico de ordenador. Algunos or- 
denadores personales modernos, como el 
IBM-PC, el DECISION MATE V de NCR o 
el PC de Eriecson, suelen: complemen- 
tarse con un disco rígido de 10 Mbytes y 
una unidad para discos flexibles (floppy 
disk) de aproximadamente 350 Kbytes por 
disco 

Tal y como propagan estas cifras, una di- 
ferencia fundamental entre los soportes 
físicos que pueden formar parte de Ja me- 
moria secundaria o memoria de masa del 
ordenador, es la densidad de información 
que pueden almacenar. 
El sistema operativo CP/M puede encon- 
trarse almacenado, dependiendo del es- 
tado de operación del ordenador, en la 
memoria primaría o bien en la secundaria. 
Por supuesto, su lugar habitual es la me- 
moria secundaria; no obstante, cuando el 
ordenador debe utilizar alguna de sus fun- 
ciones, es imprescindible que antes lo 
traslade a Ja memoria central ^ No hay que 
perder de vista que la máquina sólo puede 
procesar la información que en cada ins- 
tante reside en su memoria interna. 

ESTRUCTURA DEL 
ALMACENAMIENTO EN DISCO 



MEMORIA PRIMARIA 



En el instante de conectar ai ordenador, 
entran en juego un grupo de instrucciones 



BIOS 



BDOS 



CCP 



TPA 



SPA 



«jnjTJ-LTirun-rLri^ 

ORDENES 
DE CARGA 
EN ROM 
, T_ruT_ruT-n-n-n-r' 



CARGADOR 
DEL 
SISTEMA 



CCP 



BDOS 



1 



BIOS 



MEMORIA 
SECUNDARIA 

El proceso de carga del CPfM supone 
trasladar a la memoria central del ordenador 
los módulos del sistema operativo residentes 
en la memoria secundaria. La operación es 
iniciada por fas órdenes de carga 
procedentes de unidad central. 



que residen permanentemente en su me- 
moria central; instrucciones cuya ejecu- 
ción hará que Ja máquina inicie automáti- 
camente el proceso de lectura de la me- 
moria de masa (normalmente disco) en la 
que se encuentra almacenado el sistema 
operativo. En ciertos modelos, es posible 
que la carga no se realice automática- 
mente, sino que, en su lugar, la máquina 
comunique al usuario que está dispuesta 
a realizar dicha lectura. Ante esta sitúa - 
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PISTA N 
PISTA 1 
PISTA O 



SECTOR 
26 por pista) 



Disposición física de las pistas de grabación 
en la superficie de un disco flexible. 

ción r el usuario debe introducir el disco 
con eJ sistema operativo en la unidad de 
lectura principal del ordenador (norma I- 



PÍSTA 0 L 
PESTA 1 

7L 



LOADER 



CP/M 



PISTA 2 



CATALOGO 

DE 
FICHEROS 



14 



FICHEROS 



Estructura básica de las pistas de i disco 
flexible que almacena al sistema 
operativo CP/M. 



mente designada con las letras "A" o "S") 
y dar la orden adecuada para que empiece 
la carga. 

Si se estuvieran utilizando discos flexibles 
de simple densidad, con 26 sectores por 
pista, la localización habitual de los dife- 
rentes bloques del sistema operativo so- 
bre el disco coincidirá con la que se detalla 
en los próximos párrafos. 
La primera operación de lectura afecta al 
cargador o "loader" r situado en el sector 1 
de la pista 0. Su misión es orquestar fa 
carga de los tres bloques dei sistema ope- 
rativo y asignarles sus respectivas posi- 
ciones en fa memoria primaria del ordena- 
dor. El cargador es, en definitiva, un pro- 
grama que empieza a ejecutarse en el 
momento en el que pasa a residir en la 
memoria primaria, y que toma el control 
del proceso de carga de los siguientes 
elementos software. 
Tras el cargador, y ocupando lo que resta 
de la pista 0 y toda la pista 1 del disco, se 
encuentran los tres módulos del sistema 
operativo; CCP H BDOS y BIOS, en ese 
mismo orden. La respectiva distribución 
de las pistas es la que refleja el gráfico 
adjunto. Las restantes pistas del disco se 
destinan a ficheros propios del usuario; si 
bien, se reserva la pista 2 (la primera libre 
a continuación de las que ocupa el sis- 
tema operativo) para el catálogo de fiche- 
ros almacenados en el disco. 
En el caso del CP/M, el catálogo ocupa un 
máximo de 32 sectores; esto es, algo 
más de una pista. A su vez, los sectores 



PISTA 


SECTOR 


MODULO CP/M 


00 


01 


CARGADOR DEL SISTEMA 


00 
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00 
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00 
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BDOS 


01 


19 
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BIOS 


01 


26 




02 


01 


CATALOGO Y FICHEROS 



están distribuidos en zonas de 32 octetos, 
de fas cuales existen cuatro por cada sec- 
tor del disco. Las pistas sobre las que se 
encuentra grabado el sistema operativo 
—pistas 0 y 1 — son pistas exclusivamente 
reservadas al mismo. En ellas, ei sistema 
operativo CP/M no aparece grabado a 
modo de ficheros convencionafes, sino de 
una forma particular y única, con la que no 
será posible que el usuario lo borre inad- 
vertidamente. 

Para comprobar este extremo puede eje- 
cutarse el comando DÍR. Este presentara 
en la pantalla la lista de los ficheros resi- 
dentes en el disco. Acto seguido puede 
ordenarse el borrado de todos los ficheros 
para, a continuación, iniciar un nuevo pro- 
ceso de carga. El usuario observará que 
dicho proceso se desarrolla con toda nor- 
malidad, a pesar de que una llamada al 
comando DIR señale la inexistencia de fi- 
cheros en el disco. 

ESTRUCTURA DE LA MEMORIA 
PRIMARIA 



Distribución de pistas y sectores de pista en el disco flexible en el que reside ei sistema 
operativo CP}M. 



EJ conjunto de la memoria primaria a dis- 
posición del ordenador se encuentra re- 
partida, habitualmente, en dos zonas bási- 
cas. La primera se reserva al sistema ope- 
rativo, para que en ella almacene los datos 
intermedios de su uso exclusivo y realice 
las operaciones propias de su actividad 
como supervisor del trabajo global de la 
máquina. 

La segunda zona coincide con el área de 
memoria destinada aí almacenamiento y 
ejecución de los programas de aplicación 
El tamaño de esta última es variable, 
puesto que depende del volumen total de 
la memoria que incorpore el ordenador Al 
respecto, cabe señalar que el área desti- 
nada al sistema operativo es fija e inde- 
pendiente del espacio total. 
La distribución específica de ambas zonas 
depende de la estructura de la memoria 
central y def propio sistema operativo. 
Más concretamente, el sistema operativo 
CP/M divide la memoria en cinco partes, 
de las cuales se reserva cuatro para su 
propio uso, mientras que la quinta, deno- 
minada TPA (Transient Program Area) la 
destina a los programas del usuario. Estas 
porciones de memoria, reflejadas en la 
figura adjunta, se encuadran en las dos 
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Velocidad de ejecución de los ordenadores 



Desde que se empezaron a fabricar los 
primeros ordenadores electrónicos, en ta 
década de los 40 r el objetivo básico ha sido 
conseguir una mayor velocidad de trabajo. 
Esta es una característica dependiente de 
un factor íntimo de la máquina: el 
denominado tiempo de ciclo. 
El tiempo de ciclo equivale al intervalo que 
transcurre entre cada dos pulsaciones del 
reloj maestro que marca el ritmo de 
operación del ordenador. En consecuencia, 
a medida que se reduce el tiempo de ciclo, 
mayor será la velocidad de trabajo de la 
máquina. 

Parece evidente que para conseguir una 
mayor celeridad en las operaciones es 
preciso reducir el tiempo de ciclo. Así es, 
en efecto. Sin embargo, hay una exigencia 
fundamental a satisfacer: los componentes 
electrónicos que conforman la intimidad del 
ordenador y que operan a modo de 
interruptores, deben ser capaces de 
' actuar" (cambiar de estado) en un tiempo 
inferior al de ciclo; de lo contrario no cabe 
pensaren un ordenador en funcionamiento. 

Ahí está el condicionante rea! de la 
velocidad del ordenador. En la medida en 
que sea posible acelerar la velocidad de 
actuación de semejantes "interruptores", 
podrá minimizarse el tiempo de ciclo y, en 
definitiva, acelerar el trabajo del ordenador. 
En Jos albores de la informática moderna, 
los circuitos del ordenador estaban 
construidos a base de válvulas de vacío; 
componentes extremadamente lentos en 
su función de interruptores. Entre los 
primeros representantes de esta categoría 
de máquinas cabe citar a los ordenadores 
Z.3 y Z.4, puestos en funcionamiento en 
Berlín en el año 1941 por Konrad Zuse, El 
tiempo empleado en la operación base del 
Z.3 era de 0,43 segundos. 
El salto espectacular que ha conducido a las 
veloces máquinas actuales llegó con la 
tecnología de los semiconductores. 
Primero fueron los transistores y más tarde 
los circuitos integrados, los populares 
JJ chips". Su presencia revirtió en un drástico 
aumento de la velocidad de operación. Sin 
lugar a dudas, ef transistor y luego los 
circuitos integrados, eran "interruptores" 
bastante más veloces que las válvulas de 
vacío. 

En la actualidad, la aplicación de los últimos 
hallazgos de la tecnología de los 
semiconductores, permite crear 
ordenadores de alto rendimiento, con 
tiempos de cid o de 40 a 50 nanosegundos 
e incluso inferiores. Por ejemplo, el 
CRAY-1, un ordenador de diseño especial 



que llega a operar con tiempos de ciclo de 
12 nanosegundos. 

El salto a tiempos de ejecución aún más 
reducidos exige nuevas tecnologías. 
Además de interruptores más rápidos, es 
preciso reducir el tamaño de los mismos. 
Este último condicionante choca con el 
hecho de que a medida que disminuye el 



volumen, más problemática resulta la 
disipación del calor generado. Todos ellos 
son inconvenientes no mayores que los 
que hace cuarenta años planteaban las 
válvulas de vacío No cabe duda, pues, que 
el avance de la tecnología electrónica saldrá 
airosa del reto que supone lograr 
ordenadores cada vez más rápidos. 








SILICE 
HMOS 


9 



GaAs 
UEMT 



10' 



Relación entre 
el tiempo 
invertido en el 
cambio de estado 
y la disipación 
¡de calor, de 
algunos tipos de 
sem ¡conductores 
utilizados en los 
circuitos 
electrónicos de 
los ordenadores. 
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LOCALIZACION 
DE MEMORIA 



FUNCION 



0000-0002 

0003 

0004 
0005 - 0007 
0008 - 0037 

0038 - 003F 

0039 - 003F 

0040 - 004F 
0050 - 007F 
0080 - 00FF 



BIFURCACION A RUTINA DE ARRANQUE BIOS 
10 BYTE 

NUMERO DE UNIDAD ACTUAL 

BIFURCACION AL VECTOR DE ENTRADA BDOS 

RESERVADO INSTRUCCIONES MAQUINA 

RST7, USADO POR DDT 

RESERVADO INSTRUCCIONES MAQUINA 

RESERVADO AL MODULO BIOS 

RESERVADO BLOQUES CONTROL FICHEROS 

BUFFER DEL DISCO 



Estructura interna en ta memoria central del área SPA. 



t 

PROGRAMAS 
DE 
USUARIO 

i 
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-CABEZA DE RAM 



-XXOO + 1600 



— XX0O + 08OO 



-XX00 



Estructura de la 
memoria 
primaria o 
central de un 
ordenador 
dotado del 
sistema operativo 
CPÍM. (Las 
direcciones 
aparecen en 
código 

kexadecimal; los 
caracteres "XX" 
corresponden a 
direcciones 
genéricas). 



-0100 
-0000 



zonas básicas mencionadas: zona para el 
sistema operativo (cuatro primeras porcio- 
nes) y zona de los programas de aplica- 
ción (área TPA). 

El cargador del sistema {"leader") posi- 
ciona tos tres módulos del CP/M en la 
parte alta de ía memoria, ocupando en 
conjunto un espacio de aproximadamente 
6 Kbytes. El módulo BIOS (Basic Input 
Output System) es el localizado en el ex- 
tremo superior. Tras éste se encuentra la 
zona destinada al módulo BDOS ¡Basic 
Dísk Operating System) y, a continuación. 
Ja porción ocupada por ei módulo CCP 
(Consolé Command Proccesor) que se re- 
ferencia en su extremo inferior por medio 
del indicador CBASE. 



Las referencias BIAS (afecta al extremo 
inferior de la memoria ocupada por el mó- 
dulo BÍOS) y CBASE son genéricas, ya 
que las direcciones hexadecimales de 
memoria que les corresponden son varía- 
bles, al depender del espacio total de me- 
moria interna que equipa al ordenador. 
La porción que ocupa la zona baja de la 
memoria, con un total de 256 bytes, locali- 
zada entre las direcciones 0000 y 01 00 (en 
expresión hexadecimal), también está des- 
tinada aí sistema operativo y se denomina 
SPA (System Parameter Area), Su come- 
tido es almacenar determinados paráme- 
tros del sistema y actuar como memoria 
auxiliar para operaciones propias de su mi- 
sión. 



La zona destinada a los programas de 
usuario ocupa, normalmente, el mayores- 
pació de memoria; está situada en la parte 
intermedia de Ja misma y se denomina 
TPA (Transient Program Area), Sus di- 
recciones superior e inferior correspon- 
den respectivamente con la referencia 
CBASE, que marca el extremo inferior de 
ta zona de memoria correspondiente af 
módulo CCP, y la dirección 01 00 (extremo 
superior del área de memoria SPA). 
En algunos microordenadores —debido a 
su propia estructura de memoria y ai he- 
cho de existir ciertos programas preg raba- 
dos en memoria ROM — la dirección del 
extremo inferior del área TPA, coincidente 
con la superior del área SPA, se desplaza 
de la posición 0100 a la 4300. 

Como se ha señalado, el área de memoria 
destinada a Jos programas de usuario es 
variable; depende de la capacidad global 
de memoria deJ ordenador. De cara a esta 
variación, la referencia inicial del área de 
memoria TPA es siempre fija (0100 ó 
4300) y lo único que se altera es la direc- 
ción correspondiente a la referencia 
CBASE. Esta última variará de acuerdo a 
un múltiplo de 16 Kbytes (4000 en la refe- 
rencia hexadecimaJ), desplazándose hacia 
el extremo superior de la memoria a me- 
dida que crece el volumen de la memoria 
central de la máquina. 
Puede darse el caso de que un programa 
de aplicación resulte demasiado volumi- 
noso para la capacidad del área de memo- 
ria destinada a almacenarlo (TPA), No obs- 
tante, ello no significa, en todos los casos, 
la imposibilidad de cargar el programa en 
memoria. 

Cabe precisar que el sistema operativo 
CP/M puede permitir su carga, aunque 
con ciertas limitaciones. Al efecto, el sis- 
tema permite utilizar una porción del área 
de memoria destinada al módulo CCP, 
aunque no en su totalidad, y a su vez, 
procede a una redistribución de las zonas 
de memoria reservadas al conjunto del 
sistema operativo. 

Lógicamente, el tamaño máximo del pro- 
grama queda fijado por el área de memo- 
ría mínima con la que e! sistema operativo 
es capaz de funcionar con eficacia. Una 
vez que se ha ejecutado el programa de 
aplicación, o bien debido a una interven- 
ción directa del usuario accionando la 
combinación de teclas <CTRL-C>, la me- 
moria se reorganiza volviendo a la configu- 
ración inicial. Este proceso se denomina 
"warm start". 
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Wordstar (y 3) 

Una sesión de trabajo 

con el tratamiento de textos 



Para finalizar el estudio de la 
aplicación para el tratamiento 
de textos WORDSTAR, vamos 
a simular una sencilla pero sig- 
nificativa sesión de trabajo. Evidente- 
mente, no va a ser posible utilizar más que 
un pequeño subconjunto de las opciones 
disponibles; no obstante, ello sucede 
también así en la práctica totalidad de las 
sesiones reales. 



INTRODUCCION 



El trabajo con el WORDSTAR se enca- 
dena a través de una serie de menús, 
relacionados entre sí, que sirven de guía al 
operador. Para realizar la función deseada, 
éste se limitará a seleccionar cuál de las 
opciones ofrecidas en el menú es la opor- 
tuna. Aunque et WORDSTAR contiene 
una estructura de menús muy estudiada, 
cualquier usuario puede modificarla hasta 
acondicionarla a su gusto. El objetivo de la 
presente sesión de trabajo consistirá en 
producir un documento con el extracto de 
!a situación económica de la empresa. 
Para ello será preciso seguir los pasos que 
se detallan en los próximos apartados. 



APERTURA DEL DOCUMENTO 
Y ESCRITURA DEL TEXTO 



Antes de empezar a trabajar es preciso 
comprobar que el disquete del WORD- 
STAR se encuentra disponible y, en caso 
afirmativo, será necesario invocar sis- 
tema operativo CP/VL Tan pronto como 
aparezca en pantalla el indicador "A >'\ 



se tecleará "WS", terminando con una 
acción sobre la tecla <RETURN>. De 
esta forma tan simple, se logrará e! arran- 
que y puesta en escena del WORDSTAR; 
por supuesto, sin ningún archivo en edi- 
ción. 

En el primer menú, denominado menú sin 
archivo, es preciso utilizar la instrucción D 
para proceder a la apertura de un nuevo 
archivo. Tras ello, aparecerá en !a pantalla 
el mensaje "ARCHIVO NUEVO" durante 
varios segundos. En ese instante puede 
ya afirmarse que nos encontramos en 
modo de edición de archivos. 
La zona superior de la pantalla se verá 
ocupada por una relación de las distintas 
posibilidades de edición. En la primera de 
estas líneas, denominada linea de estado, 
se puede observar el nombre del archivo 
(p T e, SITUACION, DOC), la página, la línea 
y columna en que se encuentra el cursor, 
etc. En las siguientes, aparecen descritas 



las funciones de edición, algunas de las 
cuales se utilizarán dentro de esta sesión 
práctica, A su vez, en la última línea se 
puede visualizar la tabulación de la si- 
guiente forma: 

L ! — ! ! í S ! R 

en donde la L representa la columna de 
margen izquierdo, R la columna de mar- 
gen derecho y las admiraciones indican la 
colocación de los fabuladores. 
La parte de la pantalla que se encuentra 
situada debajo de la línea de tabulación, se 
denomina área de exhibición del archivo. 
En ella se muestra eí texto del documento 
que se está editando; en nuestro ejem- 
plo, como se trata de un archivo nuevo, el 
área de exhibición aparecerá en blanco. 
Para escribir el texto: "La situación eco- 
nómica de la empresa es brillante, como 
se puede observar ..." basta, sencilla- 
mente, con teclear letra a letra los distin- 
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tos caracteres. Si al escribir se sobrepasa 
e! margen derecho, el WORDSTAR mo- 
verá, de forma automática, la última pala- 
bra a fa siguientes línea; en consecuencia, 
el operador no tendrá que preocuparse de 
ía terminación de líneas en el texto, A este 
proceso se le denomina fin de línea auto- 
mático. 

Otra propiedad importante es Ja denomi- 
nada alineación que consiste en la inser- 
ción de espacios entre las palabras, de tal 
forma que todas las líneas finalicen en la 
columna marcada con una R en la tabula- 
ción. 

Al escribir el texto, la tecla <RETURN> 
tan sólo se pulsará cuando se dé por ter- 
minado un párrafo. 

MODIFICACIONES 
DEL TEXTO ORIGINAL 



Una vez tecleado el texto completo, 
puede surgir la necesidad de realizar mo- 
dificaciones de distinto tipo en el mismo. 
Si dicha necesidad se detecta antes de 
concluir la edición inicial, se pueden reali- 
zar las modificaciones inmediatamente; 
no obstante, si el fichero se encuentra ya 
almacenado, será necesario editarlo para 
realizar las correcciones. Las principales 
opciones de modificación son las siguien- 
tes: 



• Movimiento del cursor 
El primer paso para realizar modificacio- 
nes en un documento ya existente, es 
situar el cursor en la posición que se de- 
see actualizar Para ello se pueden utilizar 
las instrucciones "S, *D, X T, "E y ~X que, 
respectivamente, significan ir a fa letra iz- 
quierda, ir a la letra derecha, ir a la palabra 
izquierda, ir a la palabra derecha, ir a la 
línea superior e ir a la línea inferior. 

Si en nuestro ejemplo el cursor se en- 
cuentra situado en la columna 1 de la linea 
1, y deseamos modificar el texto en la 
columna 6 y la línea 10, habrá que pulsar 
~D cinco veces y "X nueve veces, hasta 
situar el cursor en el lugar deseado. Si se 
quieren realizar desplazamientos rápidos a 
través de la línea, es preferible usar tas 
instrucciones "A y T; éstas desencadenan 
saltos de palabra en palabra (sea cual 
fuere su longitud), en lugar de desplazarse 
carácter a carácter. 

Una vez situado el cursor en la posición 
apropiada, al escribir nuevos caracteres 
éstos se insertarán ''empujando" a los an- 
tiguos. A este proceso se le denomina 
inserción y se produce por defecto. Si se 
desea modificar — no insertar, sino rees- 
cribir — , los nuevos caracteres tecleados 
sustituirán a los antiguos, sin que se pro- 
duzcan desplazamientos en el texto. 

En la línea de estado, se puede visualizar 
si la edición está en modo inserción o no. 
Para entrar en modo inserción basta, sen- 
cillamente, con utilizar la instrucción "V. 



• Borrado de caracteres 
Tras efectuar una corrección, es posibe 
que queden algunos caracteres sobrantes 
a la derecha del cursor. Para borrarlos, 
que utilizar la instrucción ~G (borrar el ca- 
rácter de la derecha). Al contrario del "em- 
puje" de caracteres producido en el modc 
inserción, el borrado de un carácter im- 
plica la "absorción" de un espacio, de 
forma que el resto de fa línea se desplaza 
una posición hacia la izquierda, 

Después de haber realizado modificacio- 
nes en un texto, el margen derecho 
puede que ya no esté alineado; es res- 
ponsabilidad del operador realizar los ajus- 
tes necesarios, ya que el WORDSTAR no 
se encarga en este caso de romper líneas 
demasiado largas. 

• Realineación deí margen derecho 

La instrucción *B sirve para realinear un 
párrafo que fue escrito con fin de línea 
automático. Para ello, se coloca el cursor 
encima de la primera letra alterada antes 
de ordenar que se ejecute la realineación. 
De esta forma se modificarán todas las 
líneas del párrafo, esto es: desde la posi- 
ción del cursor hasta la última vez que se 
pulsó <RETURN> en la introducción del 
texto. 

Si se utiliza la realineación, al encontrar 
una palabra demasiado larga en un final de 
línea, el WORDSTAR puede proponer al 
operador su separación mediante un 
guión; al efecto muestra el oportuno 
mensaje y detiene Ja realineación. Con 
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F roe eso de inserción de caracteres 
e/i un texto en edición. 



La instrucción G permite el barrado de caracteres con recuperación 
de espacio, tai como muestra ía secuencia de pantallas. 



158 



Aplicaciones 



ello, permite al usuario que teclee el ca- 
rácter " o bren que oprima ~B y conti- 
núe la realineación sin colocar el guión 
propuesto. El proceso de realineación es 
relativamente lento, hasta el punto de que 
si se trabaja con un párrafo largo, et 
tiempo invertido por el WORDSTAR 
puede rozar los 30 segundos. Para que el 
operador sepa en todo momento el es- 
tado del procesador, en la esquina supe- 
rior izquierda de la pantalla aparecerá el 
indicativo J "B"; tan sólo después de finali- 
zar completamente la realineación, o 
cuando se proponga una separación de 
palabra, se podrá observar el efecto pro- 
ducido. 



• Inserción de líneas 

En determinados casos puede ser nece- 
sario introducir párrafos completos entre 
párrafos ya escritos. Por ejemplo, en 
nuestro informe de situación económica 
ya introducido, es posible que se desee 
añadir un nuevo párrafo, indicando un fac- 
tor de valoración no considerado inicial- 
mente. Para ello se puede utilizar fa ins- 
trucción A N: cada vez que se introduzca 
aparecerá una nueva línea en blanco de- 
bajo de la que contenga el cursor 

• Scrolfing 

Cuando la pantalla queda repleta de lí- 
neas, ya sea en la carga inicial o bien en 
una modificación, el texto empezará a 
desplazarse hacia arriba cada vez que el 
cursor salte a una nueva línea. Si el opera- 
dor es muy rápido tecleando, puede darse 
el caso- de que su velocidad sea superior a 
la de aparición de los caracteres en la pan- 
talla; no obstante, la pantalla se actuali- 
zará cuando "pueda", sin necesidad de 
que el operador tenga que detener su tra- 
bajo. 

Fn algunos casos aparecerá la palabra 
ESPERE" en la línea de estado, a la vez 
que se oirá una señal de aviso destinada al 
operador. Cuando esto ocurre, es reco- 
mendable dejar de escribir o escribir len- 
tamente, hasta que el WORDSTAR se re- 
cupere y desaparezca el mensaje. 

• Fin de página 

Cuando se introduce suficiente texto 
como para llenar una página del informe, 
aparecerá una línea de guiones a lo largo 
ae la pantalla con una "P" en la última 
posición: 



-P" 



INSTRUCCIONES PARA MOVER EL CURSOR, RECORRER EL TEXTO 
O REALIZAR BUSQUEDAS 



"W Recorre abajo una línea. 

"E Desplazamiento a ta línea superior. 

"R Salto a la pantalla anterior. 

"A Salto a la palabra de la izquierda. 

~S Salto al carácter de la izquierda. 

"D Salto al carácter de la derecha. 

T Desplazamiento a la palabra de la derecha. 

% Recorre hacia arriba una línea. 

"X Salto a la línea inferior, 

"C Desplazamiento a fa siguiente pantalla. 

'CTW Recorre hacia abajo continuamente. 

Tf E Salto a la parte superior del área de texto, 

TTR Salto al principio del archivo. 

A Q A A Sustituye texto. 

*Cf S Desplazamiento af lado izquierdo de pantalla, 

TTD Desplazamiento al lado derecho de pantalla, 

"QT Busca texto, 

Q"Z Recorre hacia arriba continuamente. 

CTX Cursor a la parte inferior área de texto. 

"CfC Cursor al final del archivo. 

"GO-9 Cursor a la marca. 

"Q"P Cursor a la posición anterior a la última instrucción. 

Tf K Cursor al final del bloque. 

TTV Cursor al punto de partida de! último busca u origen del último bloque. 

TTB Cursor al principio del bloque. 



Esta es la indicación dinámica de fin de 
página. Si se está de acuerdo con el punto 
en el que ocurre, el usuario debe seguir 
escribiendo normalmente. En caso con- 
trario, puede recurrir a determinadas ins- 
trucciones para especificar dónde deben 
finalizar las páginas, e incluso detallar 
cuestiones de formato (por ejemplo, indi- 
car el número de líneas que deben escri- 



birse en cada página). A este tipo de ins- 
trucciones se las denomina "de punto", 
dado que sintácticamente todas ellas co- 
mienzan por el carácter " por ejemplo: 
.PL sirve para especificar la longitud del 
papel 

MT para definir el tamaño del margen 
superior 

MB pare definir el margen inferior ... 



INSTRUCCION ~N 



2 -INSTRUCCION *N 



J 



— 



3- INSTRUCCION 'N 



ir INSTRUCCION A N 



5 INSTRUCCION ~N 



Secuencia de inserción de nuevas lineas en blanco, por medio de la instrucción N t para la 
introducción de un párrafo en el texto original. 
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RESUMEN DE INSTRUCCIONES DE TIPO "PUNTO" DEL WORDSTAR 


Instruc. 


Función 


Unidades 


Inicíalmente 


-LH 


Altura de líneas 


1 /AS pulgadas 


8=6 lineas por pulgada 


.PL 


Longitud Papel 


líneas 


66 lineasen pulgadas 


.MT 


Margen Superior 


líneas 


3 líneas=1/2 pulgada 


.MB 


Margen Inferior 


líneas 


8 líneas = 1 1/3 pulgadas 


.HM 


Margen Encabezado 


líneas 


2 líneas = 173 pulgada 


FM 


Margen Pie página 


líneas 


2 líneas=1/3 pulgada 




(margen C de página) 






PC 


Columna £ de página 


columnas 


1/2 margen derecho inicial 


,PO 


Cnirimipnto nánina 

T. — 1 1 II 1 ll^Zrl 1 ^JQ¡^I 1 PC 


columnas 


8 columnas =4/5 pulgada 


PA 


Cambio de página 






.CP 


Página Condicional 


líneas 




,HE 


Encabezado 




vacío 


,FO 


Pie de página 




número de pág. en columna .PC 


.OP 


Omite números de página 






.PN 


Número de página 




1 


CW 


Ancho de Caracteres 


1/120 pulgadas 


12 para ancho estándar 








10 para ancho alternativo 


SR 


Baja Subíndices 


1748 pulgadas 


3 


UJ 


Microalineación 


NO(O)SKI) 


si(t) 


.BP 


Impresión bidireccional 


NO(O)SIO) 


SIÍ1) 


.IG 


Comentario (o ...] 








La instrucción básica de almacenamient 
es *KD; ésta se encarga de grabar toda I 
información en un archivo en disco, con i 
nombre elegido al empezar la edición, 

IMPRESION DE 
UN DOCUMENTO 



El fin último de todo documento editado 
(y nuestro informe económico no va a ser 
una excepción) no es otro que obtener su 
impresión en papel. Para elfo, el operador 
debe asegurarse inicialmente que la im- 
presora está preparada (encendida, con et 
papel colocado, ...), Acto seguido, introdu- 
cirá la opción P del menú sin archivo, a lo 
que el WORDSTAR reaccionará con una 
pregunta: 

¿NOMBRE DEL ARCHIVO QUE SE 
DESEA IMPRIMIR? 

En ese momento, el operador debe con- 
testar con el nombre del archivo y, a conti- 
nuación, pulsar la tecla <RETURN>; su- 
cesivamente, irán apareciendo nuevas 
preguntas que conducirán a la obtención 
del documento escrito a través de la im- 
presora. 

Mientras la impresora está escribiendo un 
documento, es posible editar otro distinto 
y seguir trabajando. Sin embargo, en es- 
tas condiciones, ef tiempo de respuesta 
será muy superior; de ahí que es reco- 
mendable utilizar sólo edición simultánea 
para revisiones de textos y/o modificacio- 
nes no excesivamente importantes. 



RECAPITULACION 



El repertorio de comandos pora la edición en pan! alia del WORDSTAR, sintetiza las funciones 
necesarias para automatizar y dar eficacia a la producción de textos. 



REVISION Y ALMACENAMIENTO 
DEL TEXTO 



Para revisar todo el texto introducido an- 
tes de almacenarlo en disquetes o impri- 
mirlo en papel, pueden utilizarse las ins- 



trucciones de subir o bajar "línea a línea" 
o "pantalla a pantalla", 
Una vez satisfechos con el contenido del 
archivo en edición se puede, y debe, pro- 
ceder a su almacenamiento. Todas las 
operaciones realizadas en la sesión de tra- 
bajo sólo tienen efecto transitorio, de ahí 
que si no se transfiere el documento a un 
archivo, -no será posible conservar todo lo 
escrito. 



En esta hipotética sesión de trabajo con el 
WORDSTAR, se han puesto en juego una 
mínima parte de las instrucciones que 
brinda la aplicación. Desde luego, la des- 
cripción completa de una sesión de tra- 
bajo real exigiría mucho más espacio y no 
es el objetivo de la obra. Por ello, la des- 
cripción se [imita a los pasos usuales e 
imprescindibles para procesar un docu- 
mento sencillo. 



160 



Basic 



Almacenamiento de programas 

Grabación y lectura de 
programas en la memoria auxiliar 




GRABACION 
DEL PROGRAMA 
EN UNA UNIDAD DE 
ALMACENAMIENTO EXTERNO 



INTRODUCCION DEL 
PROGRAMA EN LA 
MEMORIA INTERNA 
DEL ORDENADOR 



Q 



El objetivo habitual de un programa no se reduce a ejecutarlo tan sólo una vez. En 
consecuencia, iras introducirlo en el ordenador a través del teclado, es conveniente grabar:. - 
en un soporte de memoria de tipo permanente (por ejemplo, cinta en cásete o disco). 



on ya numerosos ios coman- 
dos y las funciones BASIC que 
han desfilado en estas páginas 
de la obra. A estas alturas, se 
han volcado ya conocimientos suficientes 
para permitir la confección de programas, 
no excesivamente complicados, aunque 
no por ello menos interesantes. 



¿COMO CONSERVAR 
LOS PROGRAMAS? 



Un hecho fácilmente constatable es que 
una vez que se desconecta la alimenta- 
ción del ordenador, la memoria interna de 
este se borra y, en consecuencia, el pro- 
: r ama que reside en su interior desapa- 
rece. Ello constituye un grave problema, 
va que las horas de trabajo invertidas en la 
adacción de un programa se pierden, 
simplemente, al desconectar el aparato. 
No hay que olvidar que tal desconexión 
ouede producirse de una forma involunta- 
ria: por fallo en la alimentación, o al come- 
ter un error en la manipulación del apa- 
rato. 

El objetivo habitual de un programa no se 
"educe a ejecutarlo tan sólo una vez. De 
ellos se espera que sirvan para resolver una 
-ecesidad o realizar una acción más o me- 
^os frecuente. Si el operario o programador 
Tuviese que confeccionar de nuevo el pro- 
grama, cada vez que surja la necesidad de 
«solver un problema con el ordenador, 
ron ta ha con un motivo más que suficiente 
33ra disuadirle de emplear este método 
ze trabajo; posiblemente buscaría y en- 
: miraría métodos más cómodos y efi- 
caces. 

No cabe duda que ésta no es una sítua- 
: dd envidiable. En cualquier caso r cabe la 



opción de tomar nota del programa y r más 
tarde, cuando sea necesario, introducirlo 
de nuevo en la memoria del ordenador 
procediendo a su escritura desde el te- 
clado. Tampoco ésta es una solución idó- 
nea. El método sigue resultando incó- 
modo y poco eficaz. La reiterada escritura 
del programa siempre es una operación 
tediosa y que, por lo general suele aca- 
rrear problemas, Por ejemplo, un error co- 
metido al teclearlo hará que el programa 
no funcione correctamente; será necesa- 
rio localizar los errores cometidos en una 
labor complicada y que no siempre con- 
duce a un resultado inmediato. 
Pero no hay por qué alarmarse; éstas no 
son las alternativas habituales. El ordena- 
dor pone a disposición del usuario otras 




Las casetes y, en general, las cimas 
magnéticas son soportes de memoria de áp* 
secuencial. En ellas i a información se grahm 
en serie, dato a dato. De ahí que para 
acceder a un dato específico, haya qut peszr 
por todos los almacenados en paski 
precedentes. 
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Liis unidades de cásete constituyen el periférico de almacenamiento externo más económico. 
Su presencia es frecuente junio a los ordenadores personales de tipo doméstico. Algunos 
equipos deben utilizar una unidad de cásele específicamente disertada por et fabricante, no 
obstante, otros equipos son capaces de trabajar asociados a cualquier magnetófono de audio 
de upo común, 



técnicas bástanla más apropiadas; técni- 
cas que permiten almacenar los progra- 
mas para su posterior reutilización en el 
momento adecuado De esta forma, para 
conservar el programa, será suficiente 
con ordenar a la máquina que lo transfiera 
a un soporte de memoria permanente, en 
el que la información almacenada no de- 
saparezca al desconectar la alimentación. 

CSAVE 




Cada vez que sea preciso utilizar de nuevo 
el programa, bastará sencillamente con 
que el ordenador lo extraiga de la memo- 
ria permanente y lo deposite en su me- 
moria interna. Los dispositivos externos 
encargados de realizar una función de 
tanta utilidad reciben el nombre de unida- 
des de almacenamiento masivo o memo- 
rias auxiliares. Mediante la oportuna codi- 
ficación, es posible almacenar en ellas la 
información que, una vez leída por el orde- 
nador, le permitirá reconstruir el pro- 
grama. 

Las unidades de almacenamiento más 
empleadas con los ordenadores persona- 
les son las unidades de disco o de cásete. 
Ambas unidades comparten una caracte- 
rística común: basan su funcionamiento 
en las propiedades magnéticas de ciertos 
materiales. Sin embargo, existen notables 
diferencias entre ellas, y no sólo por lo 
que respecta a su constitución física, sino 
también en cuanto a su funcionamiento. 
En principio, las unidades de disco son 
notablemente más rápidas que las de cá- 



sete, a su vez, en las primeras es posic = 
acceder directamente a cualquier punto 
de la superficie del disco, con lo cual, se 
puede leer cualquiera de los programes 
almacenados en el disco sin por ello, pe- 
sar obligatoriamente por la lectura de los 
emplazados en posiciones previas. Des- 
graciadamente, ello no es posible en las 
unidades de cásete. Estas almacenan Ja 
información secuencialmente, dato a 
dato, en la superficie de una cinta de tipo 
cásete. Una idea elocuente se obtiene al 
pensar en los casetes y discos de audio, 
con los que sucede algo semejante. En un 
disco se puede oír cualquier canción cc^ 
sólo posicionar la cabeza lectora en el lu- 
gar adecuado de su superficie, mientras 
que en el cásete la cosa se complica, ya 
que es preciso bobinar o rebobinar la cinta 
hasta situarla en ef lugar adecuado, en 
consecuencia, hay que pasar por encima 
de otra información que no reviste interés 
en el acceso actual. 

En los próximos apartados se describirá la 
forma en la que se almacenan ios progra- 
mas en las unidades de almacenamiento 
más usuales, añadiendo algunas notas 
prácticas relativas a su empleo, 



GRABACION DE PROGRAMAS 
EN CASETE 



Las unidades de cásete constituyen una 
de las memorias de masa más utilizadas 
en equipos domésticos. Ef motivo funda- 
mental radica en su economía. La simplici- 
dad de estas unidades hace que resulten 
fáciles de construir y muy robustas. En 
muchos casos, incluso, no será necesario 
adquirir una de estas unidades, ya que su 
función puede realizarla un simple magne- 
tófono para casetes de audio de tipo con- 
vencional. Ello aporta algunas ventajas. 
Raro es el aficionado que no dispone de 
un magnetófono a cásete, de ahí que el 
uso de estos periféricos para el almacena- 
miento masivo resulte muy asequible y r 
desde luego, económico. 
También los soportes empleados, las cin- 
tas en cásete, son baratas y fáciles de 
adquirir. En principio, cualquier cinta co- 
mercial de audio resulta adecuada, si bien, 
es conveniente huir de las cintas de es- 
casa calidad, ya que pueden ocasionar 
problemas que conducirán a la pérdida de 
la información en ellas almacenada. Para 




Almacena un programa en la unidad de cásete, otorgando af mismo el nombre especifi- 
cado. 

Formato: CSAVE "<nombre del programa>" 
Ejemplo: CSAVE "CASA" 

162 



Basic 




CSAVE "FRQD" [CRí 
PRESS RECORD AND PlAY 
ON TAPE 



CASO 1: El ordenador relata con detalle 
debe realizar el usuario. 



introducción de 
la orden CSAVE 
seguida por una 
acción sobre ia 
tecla RETÜRN o 
ENTER 
{retroceso de 
carro). 

El ordenador 
presentará un 
mensaje 
indicativo de la 
acción a realizar: 
"pulsar las teclas 
RECORD v 
P LA Y de la 
unidad de 
cásete". 

Realizar la 
acción indicada 
por el ordenador. 

Accionar de 
nuevo la tecla 
RETÜRN de 
acuerdo a las 
indicaciones del 
ordenador, para 
que dé comienzo 
ia grabación. 

Aguardar a la 
presentación del 
mensaje 
"correctolfin de 

ia grabación'' 
fOK, READY...) 



GRABACION DE UN PROGRAMA EN CASETE 

las acciones que 



MEMORIA 



CASO 2: El usuario debe estar atento y realizar la secuencia 
de acciones pertinentes sin aguardar mensajes detallados 
del ordenador. 

MEMORIA 















































PRQGF&MA 
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Programa 
en la 
memoria 
interna. 











































PROGRAMA 
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CSAVE PiROG" ICR] 
PRESS RECORD AND FLAY 
ON TAPE 
íCRT 



C5AVE "PROG- 1CR] 



CSAVE PfiOG " LCRÍ 
PRESS RECORD AMO PLAY 
ON TAPE 
ÍCR] 

5AVING-: PRD& 
QK 



CSAVE "FfiOO" ICR|¡ 
READY 



El programa 
queda 

almacenado 
en cásete. 



Programa en la 
memoria interna. 



Introducción de 
la orden CSAVE. 



Puesta en 
marcha del 
cásete en modo 
"grabación. 

Acción sobre ia 
tecla RETÜRN o 
ENTER 
(retroceso de 
carro}. 



Aguardar a ia 
presentación del 
mensaje 
"correctolfin de 
la grabación" 
(OK, READY...) 



El programa 
queda 

almacenado en 
cásete. 



empezar el trabajo con Ea unidad de cá- 
sete, hay que contar con un programa, por 
ejemplo el siguiente: 



10 REM PROGRAMA DE PRUEBA 

20 PRINT "PROGRAMA" 

30 PRINT "DE DEMOSTRACION" 

40 PRINT "PARA EL ALMACENAMIENTO" 

50 PRINT "DE INFORMACION" 

60 PRINT "EN CASETE" 



Acto seguido, será preciso conectar la re- 
ferida unidad al ordenador; para ello, es 
necesario consultar el manual de cada 



equipo, ya que en este punto no caben 
métodos generales. 

Ahora puede ya realizarse la grabación del 
programa en cásete. Para ello, es necesa- 
rio que el ordenador transfiera una señal a 
la unidad de cásete, señal que será gra- 
bada para su posterior uso. Desde luego, 
Ja transferencia no se va a realizar- de una 
forma automática, sólo con que el usuario 
lo desee, es necesario comunicar la orden 
adecuada al equipo. Esta coincide, en mu- 
chos casos, con el comando BASIC 
CSAVE, cuya formulación es la siguiente: 

CSAVE "<nombre del fícherc»" 

El nombre del fichero es una referencia 
que identificará al fichero o bloque de da- 
tos (el programa en este caso) y que facili- 
tará su manipulación. No hay que perder 
de vista que un mismo cásete suele cons- 
tituir el soporte de almacenamiento de 



más de un programa ; por lo tanto, el nom- 
bre del fichero permitirá identificar a cada 
uno de los programas por separado. De- 
pendiendo del ordenador del que se trate, 
el nombre debe cumplir determinadas 
condiciones; por lo general, éstas se re- 
fieren a la longitud máxima del mismo, 
habitualmente de seis a ocho caracteres. 
Por ejemplo: 

CSAVE "CUENTA" 
CSAVE "PR0G" 

En ciertos casos, es posible añadir un ape- 
llido al nombre del archivo. Este apellido es 
una extensión que acompaña ai nombre; 
consiste en dos o tres caracteres, situados a 
la derecha del nombre, y separados de 
éste por un punto. 

Al ejecutar una instrucción CSAVE, el or- 
denador transferirá el programa que se 
encuentra en la memoria al cásete, en 
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Carga en la memoria interna del ordenador un programa almacenado en cásete. 

Formato: CLOAD "{< nombre del programa >]" [, R] 

Ejemplos CLOAD "PRQG" 
CLOAD " " 
CLOAD "TEMA", R 




CLOAD 



forma de señal eléctrica. Esta contiene la 
información necesaria para que, posterior- 
mente, sea posible realizar el proceso in- 
verso, esto es: leer dicha señal y recons- 
truir el programa en el ordenador. Para 
ello será necesario que la unidad de cá- 
sete se encuentre en condiciones de reci- 
bir la señal y grabarla. Al respecto, habrá 
que pulsar simultáneamente las teclas de 
grabación y avance del magnetófono, 
Desde luego, es preciso sincronizar esta 
operación con la introducción del co- 
mando. 

En algunas ocasiones, esta tarea es bas- 
tante sencilla; una vez introducido el co- 
mando, el ordenador pedirá al usuario que 
ponga a la unidad de cásete en situación 
y, tras ello, que accione una tecla (RE- 
TURN, normalmente) para que dé co- 
mienzo el proceso de grabación. En las 
correspondientes figuras aparecen dos 
secuencias de operación propias de dis- 
tintos ordenadores. 

El proceso de grabación no tiene una du- 
ración fija, sino que depende de la longi- 




tud del programa y también de la veloci- 
dad con la que el ordenador es capaz de 
enviar los datos a la unidad. El proceso 
puede durai desde unos segundos hasta 
varios minutos. En cualquier caso, no hay 
por qué preocuparse; el ordenador se en- 
cargará de informar al operario en el ins- 
tante en el que termine la grabación, pre- 
sentando en la pantalla el oportuno men- 
saje. Tras ello, es conveniente detener el 
cásete para que no siga grabando; en al- 
gunos casos — si se trata de un cásete 
especial — el propio ordenador se encar- 
gará de detenerlo. 

Algunos ordenadores no permiten la gra- 
bación de un programa con nombre; de 
ocurrir así, será suficiente con introducir el 
comando de grabación sin argumento al- 
guno: CSAVE. 

CARGA DE PROGRAMAS 
DESDE CASETE 



Cualquier programa grabado en cinta 
magnética, ya sea por el usuario mediante 
el comando CSAVE, o bien grabado por el 
fabricante del cásete si se trata de un 
programa comercial puede cargarse en el 
ordenador y ejecutarse en cualquier mo- 
mento. 

La necesidad del almacenamiento de los 



Verifica la coincidencia de un programa grabado en cinta con el que se encuentra en la 
memoria interna. 

Fórmalo: CLOAD P "<nombre del programa > " 
Ejomplo: CLOAD? "PÉP" 



programas es una realidad apuntada en 
párrafos anteriores. En cualquier mo- 
mento puede desconectarse accidental- 
mente la alimentación del aparato, o e 
propio usuario, por error, puede introducir 
un comando NEW. ¿Qué sucede en tal 
caso? La respuesta es que ta memoria de 
ordenador quedará "limpia". La ejecución 
de un comando LIST no obtendrá res- 
puesta; lo mismo sucederá con el co- 
mando RUISL El programa se ha perdido. 
No obstante, si se tomó la precaución de 
grabarlo previamente, será posible recu- 
perarlo en cualquier instante. De ahí que 
cuando se esté desarrollando un nuevo 
programa, resulte conveniente tomarse la 
molestia de hacer copias de seguridad en 
las sucesivas versiones, a medida que se 
vaya perfeccionando el mismo. De no ha- 
cerlo así, el usuario puede llevarse alguna 
que otra sorpresa, especialmente en lo 
que se refiere a la alimentación del apa- 
rato, siempre a expensas de la red. 
El comando adecuado para ordenar la 
carga de un programa almacenado en 
cinta es, normalmente, CLOAD. Su as- 
pecto general es el siguiente: 

CLOAD "cnombre del programa>" 

El nombre del programa ha de coincidir 
con el utilizado en el proceso de graba- 
ción. Sin embargo, si no se recuerda el 
nombre, éste puede omitirse; en tal caso, 
el ordenador cargará el primer programa 
que localice en la cásete. A continuación, 
se muestran algunos ejemplos de formu- 
laciones válidas del comando CLOAD: 

CLOAD "PEPE" 
CLOAD "NOMBRE" 
CLOAD - " 

La forma de trabajar con este comando es 
muy simple. Una vez introducido a través 
del teclado y tras accionar la tecla RE- 
TURN (retorno de carro), el ordenador pa- 
sará a examinar las señales procedentes 
de la unidad de cásete. En el caso de que 
la señal analizada coincida con e pro- 
grama que se desea cargar, procederá a 
su lectura y a su transferencia a la memo- 
ria interna. Para evitar errores durante la 
operación es conveniente situar la cinta lo 
más cerca posible de! punto en el que 
comienza el programa. Para ello se hace 
necesario disponer de alguna referencia 
que permita identificar el punto en cues- 
tión; por ejemplo, bastará con apoyarse 
en el estado del cuentavueltas que acos- 
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tumbra a equipar a las unidades de cá- 
sete. 

Como ya se indicó, algunos ordenadores 
no admiten eí campo correspondiente al 
nombre dentro del comando CSAVE. Por 
supuesto, tampoco lo admitirán ahora 
como argumento de CLOAD. En tal caso, 
!a carga se ordenará de forma análoga a 
cuando se desconoce el nombre otorgado 
al fichero: CLOAD" ". 



VERIFICACION DE LOS 
PROGRAMAS ALMACENADOS 



Las unidades de cásete no están exentas 
de problemas; unas veces porque falla la 
alimentación en un cierto instante, otras 
porque las cabezas lectoras o grabadoras 
están sucias, e incluso, en ocasiones, por 
efecto de interferencias originadas por se- 
ñales de radio o por algún aparato eléc- 
trico conectado a la red de tensión. Todas 
estas circunstancias repercuten en que la 
calidad de las grabaciones sea, a veces, 
defectuosa, hasta el punto de que resulte 
imposible recuperar el programa grabado. 
No cabe duda que es conveniente tomar 
algunas medidas precautorias. La primera 
de ellas consiste en realizar varias graba- 
ciones de un mismo programa, en la 
misma cinta o, preferiblemente, en otra 
distinta, A pesar de todas las precaucio- 
nes, siempre queda la incertidumbre de 
saber si el programa se grabó correcta- 
mente. 

Eí método más inmediato para eliminar tal 
incertidumbre consiste, sencillamente, en 
borrar la memoria por medio del comando 
NEW y proceder a la carga inmediata del 
programa, para verificar si es posible recu- 
perarlo. Desde luego, la operación elimi- 
nará cualquier incertidumbre, pero poco 
más, puesto que el error ya no será repa- 
rable. Si la grabación ha sido defectuosa, 
se habrá perdido el programa irremisible- 
mente. Muchos dialectos BASIC incorpo- 
ran un comando especializado que per- 
mite comprobar si fa grabación se ha efec- 
tuado correctamente. Este suele ser el 
comando CLOAD?, cuyo formato es: 

CLOAD? "<nombre del programa> rF 

En efecto, el nombre del programa debe 
coincidir con el utilizado en el instante de 
su grabación. 



Veamos cuál es su actuación. Una vez que 
se ha grabado el programa con la orden 
CSAVE, y antes de borrar la memoria o de 
introducir cualquier modificación en el 
programa, puede entrar en escena el co- 
mando de verificación. En primer lugar, 
hay que rebobinar la cinta hasta el punto 
en el que dio comienzo la grabación; tras 
ello, se introducirá la orden CLOAD? 
acompañada por el nombre con el que fue 
grabado el programa a verificar. La ejecu- 
ción del mismo hará que el ordenador 
compruebe la total coincidencia del pro- 
grama que reside en su memoria con el 
programa del mismo nombre que se en- 
cuentra en la cásete. 
En algunos dialectos BASIC este co- 
mando no recibe el nombre de CLOAD?, 
sino que obedece al nombre de VERIFY; 
no obstante, su funcionamiento es aná- 
logo al descrito. 





DIRECTORIO 



PROGRAMAS 
Y DATOS 



Las unidades de disco permiten conocer, de 
forma casi instantánea, cuál es ei número y 
nombre de ios programas almacenados en 
cada disco magnético. Ello es posible debido 
a que las referidas unidades reservan una 
:ona del disco, denominada " directorio *\ 
para el almacenamiento de dicha 
información. 



ALMACENAMIENTO EN UNIDAD 
DE DISCO 



Hasta ahora se ha hablado exclusiva- 
mente de comandos relacionados con la 
grabación y recuperación de programas 
en unidades de cásete. Esta situación no 
deja de ser frecuente, sin embargo está 
lejos de ser la más eficaz. Existen otros 
periféricos de almacenamiento, también 
popularizados, capaces de prestar un me- 
jor servicio. 



La velocidad de transferencia de información en ambos sentidos (grabación y lectura) no es 
ana de fas características propias del cásete. Cuando las exigencias se concretan en la 
necesidad de almacenar un gran volumen de información, y garantizar un acceso rápido y 
directo a la misma, es preciso optar por el almacenamiento en disco. 
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SAVE "<penférico> ; <nombre del pro- 
gramad' 

Realmente, SAVE tiene en muchos orde- 
nadores la doble utilidad de ordenar el 
almacenamiento de información tanto en 
cásete como en disco Ese es, precisa- 
mente, el motivo por el que se incluye la 
opción <periférico> en su argumento; 
ésta debe referenciar a la unidad en la que 
hay que grabar la información. La opción a 
utilizar para que el programa sea enviado a 
la unidad de cásete es CAS r aunque, nor- 
malmente, también será éste el destino 
del programa si no se especifica referen- 
cia alguna. Para elegir la unidad de disco 
como destinataria de la grabación hay que 
colocar en dicho campo el número de la 
unidad implicada [1 r 2, ...). El nombre del 
programa ha de ajustarse a unas condicio- 
nes semejantes a las que se imponían en 
el caso del cásete; esto es: no debe so- 
brepasar una determinada longitud (longi- 
tud que varía de uno a otro ordenador) y 
puede admitir o no "apellidos", depen- 
diendo de la máquina en cuestión. Los 
siguientes ejemplos son formulaciones 
habituales del comando SAVE: 

SAVE "CAS.LOCr 
SAVE "1:GUSA" 
SAVE *7:CASA r 
SAVE JI PRÜG" 

Cuando se trabaja con una unidad de cá- 
sete, el usuario se ve obligado normal- 
mente a realizar las funciones de controla- 
do r de la cinta; en tal caso, el ordenador 
trabaja "a ciegas" grabando o leyendo de 
la zona en la que esté posicionado el cabe- 
zal, y sin comprobar sí en ese lugar había 
algo previamente grabado. Desde luego, 
ello significa que en una misma cinta es 
posible grabar dos programas con el 
mismo nombre. Esta característica no es 
extensiva a la unidad de disco. Ahora, el 
ordenador es el encargado de controlar el 
disco, auxiliándose para ello en el directo- 
rio. En consecuencia, si se ordena la escri- 



Graba el programa que se encuentra en la memoria del ordenador en una unidad de 
almacenamiento externo (disco o cásete). 

Formato; SAVE "[<perif ético de destine» :~\ [< nombre del programa>]" 

Ejemplos: SAVE "CAS : GAME" 
SAVE "1 : CATO" 



AJ marge- ~e as unidades de cásete, las 
más evre— zzs son las de disco flexible. 
Estas úfcrr^s presentan grandes ventajas, 
especialmente por lo que respecta al 
tiempo oe acceso a los programas y a la 
velocidad se carga y grabación de los 

IT S ~ Z S 

Una notable prestación de las unidades de 
disco es que, de manera instantánea, es 
= ronocer el número de programas 
almacenados en el disco, así como sus 
respectivos nombres. Hay que tener en 
cuenta que las unidades de disco reservan 
una zona del soporte, denominada direc- 
torio, para almacenar dicha información. El 
directorio es una suerte de índice o catá- 
logo en el que están reflejados todos y 
cada uno de los programas que se han ido 
grabando, señalando su localización 
exacta en el soporte. Con ello, es posible 
acceder directamente a cada uno de los 
programas tras una consulta al directorio. 
La desventaja de estas unidades frente a 
las de cásete reside en el precio, notable- 
mente superior; aunque como contrapar- 
tida ofrecen unas prestaciones superio- 
res, que permiten el empleo de pequeños 
ordenadores en aplicaciones (comercia- 
les, de gestión...) que sin su colaboración 
quedarían vedadas. 

La operación básica a realizar con una uni- 
dad de disco consiste en la grabación de 
programas. El comando BASIC al efecto 
suele coincidir con SAVE, cuya formula- 
ción habitual es: 





Por efecto de la orden SA VE, la información 
contenida en lú memoria central del 
ordenador fluye hacia la unidad de 
almacenamiento externo; esta última se 
encarga de grabarla en el soporte adecuado. 

tura de un programa cuyo nombre coin- 
cide con el de otro programa presente en 
el disco, el ordenador grabará dicho pro- 
grama encima del ya existente. Dado que 
el control de la unidad de disco es auto- 
mático, el trabajo del operador se limita a 
comunicar a la máquina las instrucciones 
adecuadas. 

LECTURA DE PROGRAMAS 
EN DISCO 



Para recuperar los programas de la unidad 
de disco es necesario recurrir al comando 
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TABLA DE CONVERSION 




CLOAD 


CSAVE 


Verificación: 


LOAD 


SAVE 


Autoejecución 


ORDENADOR 


CLOAD 


CSAVE 


CLOAD? 


LOAD "<per,> : 1 


SAVE "<per.>: 


CSAVE 


LOAD "<pei\>: 




"<nom.>" 


"<noiti.>" 


"<nom,>" 


< n o m > > 1 ' 


<nom.>" 


<nom.> , autu 


<nom.>" ( R 


APPLE II 






VERIFY 


LOAD 


SAVE 





RUM 


(APPLESOFT) 






"[nom,f 


"[nomj 1 


"[nom.]" 




[nom.] 


APRICOT 
(M-BASIC) 


— 


— 




LOAD 

"<nom.>" 


SAVE 
"<nom.>" 


— 


luau <pei\>. 
<nom.>", R RUN 
'<nom.>" [<, R>] 


ATARI 


CLOAD 


CSAVE 




LOAD "<per >: 
<nom.>" 


SAVE "<pei\>: 
<nom.>" 






CBM 64 






VERIFY H<nom.>n 
í <per.>] 


LOAD ["<nom.>"] 
l <per.>] 


SAVE ["<nrjm.>"] 
í <per >] 





(t) 


DRAGON 


CLOAD "<nom.>" 


CSAVE N <riDm.>" 












EQUIPOS 


CLOAD 


CSAVE 


CLOAD? 


LOAD "<per>: 


SAVE "<per.>: 




LOAD "<pei\>: 


MSX 


['<nrjm.>"] 


"<nom.>" 


["<nom>"] 


<nom.>" 


<nom.>" 




<nom.> j n 


HP-150 








LOAD "<nom.>" 


SAVE HJ <rom.>" 




LOAD "<rom.>" ( R 


IBM PC 


— 


— 


— 


LOAD "<per>: 
<nom,>" 


SAVE '<per.>: 
<nom.>" 


— 


LOAD "<per,>: 
<nom.>" r R 


MPF 


LOADT "<nora>" 


SAVET "<nom.>" 


— 






— 




NCR DM-V 


CLOAD 


CSAVE 


CLOAD? 


LOAD 


SAVE 




LUAU *--p6r. 


(MS-BASÍC) 


JI <nom.>" 


"<nora>" 


"<nom,>" 


"<nom.>" 


"<nDm.>" 


— 


<hoin,>" ( R 


NEW BRAIN 


LOAD 


SAVE "<riQm.>" 


VERIFY 


. 


— 






ORIC 


CLOAD 


CSAVE 


CLOAD 






CSAVE 




"[<nom.>]" 


"<nom.>' É 


"[<norrK>]'\ V 






"<nom,>" AUTO 




SHARP MZ-700 


LOAD 


SAVE 


VERIFY 










(MZ-BASIC) 


"[<noin.>]" 


"[<nom>]" 


"[<nom.>]" 










SINCLAIR QL 


CLOAD 

"<nom.>" 






LOAD □ <per.> 
<nom.> ["] 


SAVE Pl <per.> 
<nom r > ["] 






SPECTRA- 


CLOAD 


CSAVE 


CLOAD? 


LOAD J <per>: 


SAVE "<per>: 




LOAD "<per>: 


VIDEO 


"<no¡u>" 


"<nom,>" 


"<nom.>" 


<nom r >" 


<rom.>" 




<nom.>" R 


ZX-SPEC- 


LOAD 


SAVE 


VERIFY 






SAVE "[<noril>T 




TRUIVI 


"[<nom.>]" 


"[<nom>]" 


"[<nom.>]" 






UNE <n> 





<nom>: Nombre del programa con el que se trabaja. <per,>: Especifica el periférico a emplear. 



FORMULACIONES DE LOS COMANDOS 

CLOAD <nom.>: Carga en memoria el programa almacenado en cásete cuyo nombre coincide con el especificado. CSAVE <nom.>: Graba en cásete e! programa 
almacenado en memoria, otorgándole el nombre indicado. CLOAD? <nom.>: Comprueba la total coincidencia del programa cargado en memoria con el residente en la 
unidad de cásete, LOAD J <per >: <nom.>": Carga en memoria el programa indicado que reside en la unidad de almacenamiento externo que se especifica en la zona 
<per>. SI se omite la opción <per>, la unidad implicada será la de disco. SAVE "<per.>: <nom> rr : Almacena en el periférico indicado el programa almacenado en 
-memoria, otorgándole el nombre señalado. Cuando la elección de periférico no existe, la grabación se realizará en la unidad de disco. CSAVE "<nom.>, AUTO: Graba en 
cásete el programa indicado, acompañado de un indicativo que hará que el ordenador lo ejecute automáticamente en el momento de cargarlo en la memoria interna. LOAD 
w <per.|>: <nom.>'\ R: Formulación del comando LOAD que ordena la autoejecución del programa una vez concluida la carga en memoria. 

OBSERVACIONES: 

1) En el CBM 64, la instrucción LOAD como parte de un programa implica la ejecución de dicho programa. 

2) El sistema operativo canaliza la instrucción al periférico adecuado {cásete o disco). 
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Caros en la memoria del ordenador un programa residente en una unidad de almacena- 
miemo extemo. La opción '\ R" ordena su autoejecución automática. 

Formato: LOAD "[<penférice>:] [<nombre de! programa>)" [ t R] 

Ejemplos: LOAD JJ 1 : EXAMPLE" 
LOAD "CAS: " 
LOAD "PEPE", R 



LOAD "CAS:CARP" 
LOAD "2:MI0" 

Como observación final, cabe añadir que 
al realizarse la lectura y transferencia de] 
programa desde la unidad de disco a la 
memoria central, quedará borrado el con- 
tenido previo de esta última. 

AUTOEJECUCION 
DE PROGRAMAS 




Ü\ LOAD 




LOAD, cuya formulación general coincide 
con: 

LOAD "<periférico> : < nombre del pro- 
grama^', R 

Las opciones son las mismas que las del 
comando SAVE, de tal forma que es nece- 
sario especificar el periférico y el nombre 
del programa. La R que aparece como 
campo final separado por una coma, sirve 
para indicar a la máquina que el programa 
debe ser ejecutado automáticamente al 
concluir la operación de carga. Su presen- 
cia sustituye virtualmente al comando 
RUN. Dos ejemplos de formulación co- 
rrecta son: 



Al ejecutar una instrucción LOAD, la 
información almacenada en el soporte 
externo es leída por e¡ ordenador y 
depositada en la memoria central, 



Verifica la coincidencia del programa cargado en la me mona interna con el que se encuentra 
en la unidad de almacenamiento. 

Forma to : LOA D ? M [ <penféhco >:] [ < nombre de! programa > ] 
Ejemplo: LOAD? "CAS: BUT 



En ciertos casos, es necesario que un pro- 
grama que se encuentra en una unidad de 
almacenamiento externo, se autoejecute 
inmediatamente tras ser cargado en la 
memoria central. La necesidad puede 
obedecer a distintas causas. Por ejemplo, 
puede ocurrir que, por algún motivo, sea 
necesario encadenar programas (el pro- 
grama en curso llama a otro que se en- 
cuentra en la unidad de almacenamiento). 
En tal situación, es necesario, o cuando 
menos conveniente, que el programa lla- 
mado se ejecute automáticamente, sin 
necesidad de que el operador intervenga 
en el proceso. Esta opción se utiliza con 
frecuencia para proteger programas pro- 
fesionales, de tal forma, que la ejecución 
del referido programa no pueda ser dete- 
nida para analizar su codificación y, posi- 
blemente, copiarlo. 

Una de las posibilidades para ordenar la 
autoejecución reside en la opción R" 
que puede acompañar al comando LOAD; 
por ejemplo: 

LDAD "CAS:PEPE",R 
LOAD "1:PR0GRAM"R 

El tradicional comando de ejecución, 
RUN, también es utifizable en ciertos dia- 
lectos BASIC para este cometido. En tal 
caso, admite una formulación distinta a la 
ya conocida. Esta es: 

RUN "<periférico> : <nombre>" 

Al ejecutarla se consigue el mismo resul- 
tado que con LOAD y la opción R. Hay que 
precisar que la opción <periférico> debe 
figurar tal y como se indicó en un apartado 
precedente. Por lo demás, el nombre co- 
rresponde al otorgado al programa a eje- 
cutar. Por ejemplo: 

RUN "CAS:PEPE" 
RUN J '2:PR0G8" 
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Logo (8) 



TURTLE GRAPHICS: 

el color y los movimientos relativos 




n tos capítulos dedicados 
hasta el momento al trazado 
de gráficos por medio de la 
tortuga, se han estudiado 
algunas de las posibilidades que brinda el 
LOGO para crear dibujos en la pantalla. A 
lo largo de esta nueva incursión en el te- 
rreno del "turtle graphics", van a am- 
pliarse las herramientas disponibles. Ello 
permitirá programar dibujos más comple- 
jos y espectaculares, a través de un con- 
trol más flexible y potente de la actividad 
de la "tortuga gráfica". 

LA TORTUGA SE ESCONDE 



Una vez terminado un dibujo, puede ser 
conveniente evitar la presencia de la tor- 
tuga. Para conseguirlo, puede desplazarse 
a la tortuga a una esquina de la pantalla. 
No obstante, el método más eficaz es or- 
denarla que se esconda. Para ello, se dis- 
pone del comando HT (Hide Turtle). Este 
comando vuelve invisible a la tortuga, aun- 
que no impide su movimiento ni altera el 
modo de dibujo seleccionado (PD, PE, PU 
o PX). Si se desea recuperar su presencia, 
bastará con teclear la orden opuesta ST 
Show Turtle). 

Existe otro método para perder el con- 
:acto visual con tan simpático personaje: 
obligarlo a traspasar los límites de la pan- 
talla. Hay dos alternativas para fijar dichos 
límites; éstas coinciden con los denomi- 
nados modo abierto y modo cerrado. 
En el primero, la pantalla muestra única- 
mente una parte del campo de acción de 
a tortuga. Si la tortuga sale de esta zona 
visible o ventana, desaparecerá de la vista 
3 el usuario. Este modo se selecciona con 
el comando WIN DOW (ventana). 



HT 




HIEH 



El comando HT hace que ía tortuga 
desaparezca de la pantalla; a pesar de elh, 
ésta puede seguir trazando dibujos que serán 
visibles. Para restaurar su presencia, es 
preciso utilizar el comando ST. 

En el segundo caso, modo cerrado, la 
tortuga no puede salir de la pantalla. Si 
intenta evadirse por un extremo, apare- 
cerá de inmediato por el opuesto. Una 
imagen gráfica de tal situación se obtiene 




al pensar que la pantalla es una lámina 
flexible, a la que doblamos y pegamos sus 
lados opuestos; esto es: el borde iz- 
quierdo con el derecho y el superior con el 
inferior. En tal caso, es obvio que si la 
tortuga desaparece por el borde superior, 
reaparecerá de inmediato por el inferior. 
Y, análogamente, si se ausenta por el fado 
izquierdo de la pantalla, reaparecerá ins- 
tantáneamente por el lado derecho Para 
optar por este segundo modo se dispone 
del comando WRAP (enrollar). Es preciso 
tener cuidado al usar estos dos comandos 
oues ambos borran la pantalla. 
Es posible que, en determinado mo- 
mento, no se vea a la tortuga y se ignore 
si está escondida o se encuentra fuera de 
la pantalla. En éste y en otros casos se- 
mejantes, es aconsejable el uso de 
SHOWNP, El operador SHOWNP de- 
vuelve el valor FALSE si se ha ejecutado 
una orden HT para obligar al quelonio a 
desaparecer. Su ejecución permite cono- 
cer el estado actual, visible o invisible, 
activado por los comandos ST o HT, res- 
pectivamente. Si lo que ocurre es que la 
tortuga ha salido de la pantalla, pero no se 
le ha ordenado esconderse, SHOWNP 
responderá con TRUE. 

TIZAS DE COLORES 



Al operar en modo cerrado, seleccionado con 
el comando WRAP, la tortuga reaparecerá 
en la pantalla por el extremo opuesto al que 
ha desaparecido. 



Por el momento se han confeccionado 
dibujos, más o menos complejos, contro- 
lando los desplazamientos del personaje 
central del "turtle graphics", pero siempre 
a base de trazos de un solo color. Desde 
luego, los dibujos resultarían más atracti- 
vos si fuera posible colorearlos. 
En primera instancia, las posibilidades de 
elección de color dependen del ordenador 
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que se utüoe. AJ respecto, es preciso con- 
sultar eí manual propio del aparato con 
:: e:: :e =r - ovechar las distintas opcio- 
tE :,t : "da. Una vez precisadas las 
: i : t 5 :e color del equipo, hay que 
zcí- práctica los medios que incor- 
□03 e -OGO para controlar las tizas de 
:: 

z_ - — — i pio r hay que señalar que la tor- 

suede transportar más de una tiza. 
Es .bs están numeradas para facilitar su 

identificación. 

Para cambiar de tiza se utiliza la orden 
SETPN, seguida por el número de tiza de- 
seado. Dicho comando permite trazar di- 
bujos que aparecerán en la pantalla con el 
color seleccionado. La nueva tiza seguirá 
utilizándose hasta que se cambie de 
nuevo su color al ejecutar un nuevo co- 
mando SETPN. El número habitual de ti- 
zas que puede transportar la tortuga se 
eleva a tres. Por otra parte, en cualquier 
momento se puede identificar el número 
de tiza en uso, por medio del operador 
PN; su ejecución indica cuál es el número 
de la tiza en acción. 

Lo más frecuente es que el ordenador 
permita utilizar un número de colores su- 
perior a tres. Para hacer uno de los restan- 
tes colores será necesario cambiar el 
juego de las tres tizas que puede viajar 
con la tortuga. El comando que reasigna 
los colores de las tizas es SETPC SETPC 
exige dos entradas: la primera debe coin- 
cidir con el número de tizas a reasignar, 
mientras que la segunda debe ser un nú- 
mero que identifique a uno de los colores 
que permite utilizar el ordenador. 
El operador PC constituye una herra- 
mienta de ayuda para el usuario en este 
punto, puesto que al utilizarlo acompa- 
ñado por un número de tiza, la máquina 
responderá con el número del color asig- 
nado a la misma. 

CAMBIO DEL FONDO 



Al emplear tizas de colores puede ocurrir, 
en algún caso, que se esté pintando con 
una tiza cuyo color coincide con el color 
del fondo. De darse esta situación, los 
dibujos no resultarán visibles. Para solven- 




De pendiendo de las propias características 
del ordenador, la tortuga será capaz de 
utilizar un mayor o menor número de tizas de 
colores. En todo caso, hay que tener en 
cuenta que ésta soto puede (levar un número 
reducido de tizas. Para que le sea posible 
utilizar los restantes colores, debe 
intercambiar las correspondientes tizas con 
ias que lleva ' puestas ' en ese preciso 
instante. 




AVANZAR 



RIGHT 135 



I GIRAR 

I IDENTIFICAR POSICION ACTUAL 



tar esta situación, el LOGO permite alterar 
el color del fondo de la pantalla. 
El comando adecuado es SETBG (SET 
BackGround). Al igual que ocurre con las 
tizas, los colores disponibles dependerá r 
de la gama que ofrezca el ordenador, 
SETBG debe ir seguido por el correspon- 
diente número de color. Esta posibilidac 
permite alterar con comodidad el escena- 
rio del dibujo: verde para un paisaje cam- 
pestre, azul para un fondo marino o negro 
para una escena galáctica. 
De nuevo, el usuario puede averiguar er 
cualquier momento cuál es el color del 
fondo, Para ello cuenta con el operador 
BG (BackG round). BG devuelve el número 
correspondiente al color actual de la pan- 
talla. 

El empleo conjunto del comando SETBG y 
del operador BG permite múltiples posibi- 
lidades. Por ejemplo: 

SETBG SUM 1 BG 

recupera el número de color, le suma una 
unidad, y utiliza el resultado para definir el 
nuevo color de fondo. Con ello, cada vez 
que se ejecuta esta orden se altera el 
color de la pantalla, pasando al color cuyo 
código coincide con el siguiente en nú- 
mero. 



DE LO RELATIVO A LO ABSOLUTO 



Secuencia de pasos necesarios para situar a 
la tortuga en un determinado punto de ta 
pantalla. 



Los desplazamientos producidos por las 
órdenes FORWARD y BACK se denomi- 
nan relativos. Este apelativo se refiere al 
hecho de que la posición final o de destino 
de la tortuga depende de su situación de 
partida. Asimismo, la orientación de la 
tortuga por efecto de LEFT o RIGHT tam- 
bién es relativa: una misma orden LEFT o 
RIGHT dejará a la tortuga en una orienta- 
ción distinta según sea la orientación ini- 
cial o anterior a recibir la orden. Si lo que 
se desea es situar a la tortuga en un punto 
determinado y cor? una orientación espe- 
cífica, es preciso seguir una serie de 
pasos; 

— Identificar la posición y orientación 
actuales. 

— Orientar a la tortuga en dirección al 
nuevo punto. 
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— Avanzar el número necesario de uni- 
dades. 

— Girar hasta la orientación deseada. 
E! proceso puede simplificarse mediante 
et uso previo del comando HOME (tras- 
lado al origen), con lo que ¡a posición y 
orientación inicial de la tortuga resultarán 
conocidas (las iniciales al encender la má- 
quina). En todo caso, este método supone 
el paso de la tortuga por el centro de la 
pantalla. 

Las órdenes para el desplazamiento abso- 
luto eliminan toda esta suerte de inconve- 
nientes. Con un solo comando, SETPOS, 
es posible situar a la tortuga en la posición 
de la pantalla que se desee. Esta debe 
especificarse por medio de sus coordena- 
das, expresadas en forma de lista. Dichas 
coordenadas serán las cartesianas (eje Xy 
eje Y r en ese mismo orden) referidas, por 
lo general, al centro de la pantalla. 
Por ejemplo, la orden SETPOS [50 25] 
coloca a la tortuga a 50 unidades hacia la 
derecha y 25 hacia arriba del origen o cen- 
tro de la pantalla, sea cual fuere su posi- 
ción actual. Como es habitual, si la tortuga 
tiene la tiza activada (bajada), aparecerá en 
la pantalla el trayecto recorrido, que coin- 
cidirá con una línea recta. En caso de 
duda, es posible conocer las coordenadas 
del punto en el que está situada la tortuga. 
Al efecto, se dispone del operador POS; 
éste devuelve una lista conteniendo di- 
chas coordenadas. El uso de POS permite 
almacenar las coordenadas de un punto 
de la pantalla para, posteriormente, utili- 
zarlas en orden a ubicar en él a la tortuga 
por medio de SETPOS. Por ejemplo: 

PENUP 
LEFT 123 
FORWARD 73 
MAKE "PUNTO POS 
HOME 
BACK 29 
SETPOS : PUNTO 

En el ejemplo, se selecciona una posición 
cualquiera por medio de LEFT y FOR- 
WARD. Las coordenadas de esta posición 
se almacenan en la variable PUNTO, A 
continuación, se utilizan las órdenes 
HOME y BACK para alejarse del referido 
punto. Por último, SETPOS PUNTO res- 
:aura a la tortuga en el lugar elegido. 
Las dos órdenes mencionadas ejecutan 
un desplazamiento absoluto definido por 
las coordenadas. El uso de coordenadas 
permite definir un nuevo tipo de movi- 
miento: el desplazamiento intermedio en- 




Efecto sobre la tortuga del comando 
SETPOS: desplaza a ta tortuga en modo 
absoluto a la posición cuyas coordenadas se 
incluyen en la lista que acompaña al 
comando. 



tre el absoluto y el relativo. Un desplaza- 
miento de este tipo se obtiene variando 
únicamente una de las coordenadas. El 
siguiente procedimiento ilustra tal posibili- 
dad; traslada la tortuga al punto cuya abs- 
cisa [posición X) se indica, sin variar su 
ordenada (coordenada Y): 



T0 SETPOSX :X 
MAKE "Y IAST POS 
SETPOS [ :X :¥] 
END 



altere la coordenada Y r manteniendo la 
posición horizontal [coordenada X). Res- 
pecto al ejemplo precedente, el nuevo 
procedimiento sustituirá las X por Y, las Y 
por X y LAST por FIRST. 
A continuación se introducen nuevas ór- 
denes que permitirán simplificar al má- 
ximo este procedimiento. Su cometido es 
facilitar la reutilización de alguna de las 
coordenadas de la posición inicial de la 
tortuga. 

El lenguaje LOGO incorpora dos operado- 
res útiles al efecto, estos son XCOR e 
YCOR. El primero devuelve el valor de la 
abscisa (coordenada X), e YCOR hace lo 
propio con el valor de la ordenada (coorde- 
nada Y). Utilizando esta nueva opción el 
procedimiento anterior quedará de la si- 
guiente forma: 

TO SETPOSX :X 
MAKE J 'Y YCOR 
SETPOS [ :X :Y] 
END 

O mejor aún: 



TO SETPOSX :X 
SETPOS [ :X :YC0R] 
END 



El cometido del operador LAST es extraer Los dos próximos comandos simplifican 

la ordenada de la posición actual; ésta se aún más el procedimiento. En realidad lo 

utiliza al definir la nueva posición, asig- reducen a la nada, puesto que realizan 

nando a dicho valor a :Y. Un procedí- específicamente dicho cometido. Estos 

miento complementario a éste será el que son SETX y SETY. Con SETX se varía la 




El comando SETH permite orientar a 
ta tortuga en la dirección y sentido 
definido por el ángulo que constituye 
su dato de entrada, HEADING es un 
operador capaz de indicar ta 
orientación actual de la tortuga, 
expresada en grados. 
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TABLA DE ORDENES DEL 
"TURTLE GRAPHICS" (1) 


r sujeción 


Cometido 


Ope rador/co ma ndo 


HT 


Esconde a la tortuga 


Comando 


ST 


Muestra a fa tortuga 


Comando 


SHOWNP 


Devuelve TRUE si la tortuga es visible 


Operador 


WINDOW 


Activa el modo en el que la pantalla sólo repre- 
senta una parte del campo de la tortuga 


Comando 


WRAP 


Activa el modo cerrado en el que la tortuga no 
puede salir de la pantalla 


Comando 


SETPN<NT> 


Utiliza la tiza número <NT> 


Comando 


SETPC<NT><NC> 


Adjudica a la tiza <NT> el color <NC> 


Comando 


SETBG<NC> 


Pone el fondo de color <NC> 


Comando 


PN 


Devuelve el número de tiza utilizado 


Operador 


PC<NT> 


Devuelve el número del color de la tiza <NT> 


Operador 


BG 


Devuelve el número del color de fondo 


Operador 


<NT>: número de tiza. 
<NC>: número de color. 


TABLA DE ORDENES DEL 
"TURTLE GRAPHICS" (2) 


Instrucción 


Cometido 


0 pe rado r/co m a ndo 


SETPO$<IÍsta> 


Sitúa a la tortuga en la posición dada por las 
coordenadas de la lista 


Comando 


POS 


Devuelve una lista conteniendo las coordenadas 
del punto donde se encuentra la tortuga 


Operador 


XCOR 


Devuelve el valor de la coordenada X del punto 
actual 


Operador 


YCOR 


Devuelve el valor de la coordenada Y del punto 
actual 


Operador 


SETX< número > 


Sitúa a la tortuga en el punto de coordenada X, 
dada por <número> 1 sin variar su coorde- 
nada Y 


Comando 


SETY<número> 


Sitúa a ía tortuga en el punto de coordenada Y, 
dada por < número>, sin variar su coorde- 
nada X 


Comando 


SETH<número> 


Sitúa a la tortuga con la orientación dada por 
<"número> 


Comando 


HEADING 


Devuelve la orientación actual de la tortuga 


Operador 




La orientación definida por el comando 
SETH afecta a la tortuga en términos 
absolutos; esto es; la tortuga girará hasta 
orientarse en el ángulo indicado, medido a 
partir de la vertical y en el sentido de las 
agujas del reloj. 



posición horizontal de la tortuga sin alterar 
la vertical mientras que SETY mantiene la 
posición horizontal (coordenada X) modifi- 
cando la vertical (coordenada Y). 



CAMBIO DE ORIENTACION 



Las órdenes de movimiento presentadas 
en los párrafos precedentes, conducen a 
un cambio de posición que mantiene la 
orientación inicial de la tortuga. Los co- 
mandos LEFTy RIGHT, anteriormente co- 
mentados, se utilizan para un cambio rela- 
tivo de orientación: ordenan el giro de la 
tortuga en un determinado ángulo a partir 
de la orientación actual 
Para ordenar el posicionam tentó en modo 
absoluto se dispone de SETH (SET Hea- 
ding). El ángulo de orientación debe ser 
expresado en grados, tomando como ori- 
gen (generalmente) el eje vertical, en sen- 
tido hacía arriba, y realizándose el giro en 
el sentido de las agujas del reloj. Así, por 
ejemplo, SETH 90 coloca a la tortuga mi- 
rando hacia la derecha. 
Existe, asimismo, un operador que de- 
vuelve el ángulo de orientación actual de 
la tortuga. Este es HEADING; un operador 
que responde expresando la orientación 
en los términos antes señalados. 
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Introducción al MP/M 

Características generales del sistema 
operativo multiusuario 



! igual que el CP/M, el MP/M 
es un sistema operativo para 
microordenadores basados en 
los microprocesadores 8080 y 
8085 de Intel y Z80 de Zilog. Su principal 
característica es que gestiona el trabajo 
de varios usuarios con la misma unidad 
central de proceso {CPU), En definitiva, 
introduce el concepto de multiusuario, 
justificando plenamente las siglas que le 
dan nombre: "Multí-Programming Moni- 
tor". 

Por lo tanto, la configuración física nece- 
saria requiere la presencia de un solo mi- 
cro procesador, de los anteriormente men- 
cionados. Con la colaboración del MP/M, 
éste será capaz de gestínar la información 
procedente de los diversos usuarios, y es- 
lará en situación de controlar a los distin- 
tos dispositivos periféricos que formen 
parte del sistema: terminales, impreso- 
ras, unidades de disco... Para llevara cabo 
estas funciones, el sistema operativo 
MP/M exige una capacidad de almacena- 
miento en la memoria central del ordená- 




is/ MP¡M es un sistema operativo 
multiusuario, capaz de soportar el trabajo de 
hasta 16 usuarios (numerados del 0 a! 15) 
conectados ai mismo ordenador. 



dor de al menos 32 Kbytes de RAM, Ade- 
más, requiere la presencia en e¡ equipo de 
un reloj de tiempo real, adecuado para 
contabilizar el tiempo que cada proceso 



desencadenado por urr usuario puede es- 
tar accediendo a la CPU. 
En términos generales, el usuario se en- 
contrará virtualmente inmerso en un sis- 
tema monousuario de tipo CP/M, ya que 
el sistema operativo MP/M u ti tiza el 
mismo módulo BDOS que forma parte del 
CP/M. Tal circunstancia permite una total 
compatibilidad con los programas desarro- 
llados bajo el sistema operativo CP/M; 
éstos pueden ser ejecutados en un en- 
torno multiusuario sin necesidad de some- 
terlos a ningún cambio. 



LOS USUARIOS DEL SISTEMA 



El número de usuarios que puede sopor- 
tar el sistema operativo MP/M se eleva a 
un máximo de 16, Cada uno de los usua- 
rios está referen ciado por un número de 
identificación propio (del 0 a! 15). Al res- 
pecto, hay que señalar que el número de 
usuario no debe confundirse con el nú- 
mero que tienen asignado los diversos 
terminales o puestos de trabajo de! sis- 
tema. Aunque ambos números pueden 
coincidir en algún caso, se refieren a con- 
ceptos distintos; un determinado usuario 
no tiene por qué estar asignado perma- 
nentemente a una misma pantalla física, ni 
viceversa. 

Cada usuario dispone de una zona de al- 
macenamiento en disco reservada para su 
uso exclusivo. Este es "dueño" de los 
ficheros y programas que residan en la 
misma. Los distintos usuarios son total- 
mente independientes, hasta el extremo 
que dos de ellos pueden tener almacena- 
dos en sus respectivas zonas dos progra- 
mas idénticos, e incluso con el mismo 
nombre. Por supuesto, en cada situación 




En ios equipos regidos por el MPjM, cada usuario dispone de una zona de memoria reservada 
para su uso exclusivo. La única excepción aparece en la zona reservada ai usuario 0; ésta 
ultima, utilizada por el sistema, no es exclusiva, sino que todos los usuarios pueden acceder a 
la misma en modo lectura, 
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se ejecutará e! programa que corres- 
ponde, seg^n sea un usuario u otro quien 
líame ¿ recama en cuestión. 
La z: _ z "rEe - , 5da para el usuario cero es 
utilizada oor el sistema. Esta no es exclu- 
siva : ■ : : as de uso común. Todos los 
^s.a iz ;:;n los números del 1 al 15) 
t s-=- e posibilidad de acceder a ella en 
ir actura, esto es; pueden exami- 
nar v ejecutar los programas que se en- 
:_t--'5" en ella, aunque no pueden en 
ningún caso alterar su contenido, 
^rs ^ versos programas almacenados en 
a cuarto cero tienen, por lo general, un 
carácter complementario de los coman- 
/ utilidades del sistema. Suelen ser 
ae uso frecuente por parte de los diferen- 
tes usuarios, Este hecho contribuye a op- 
:~ : zar el espacio ocupado en disco, ya 
que se evita la posible duplicidad de pro- 
gramas al estar centralizadas la mayoría 
de las utilidades. 

Cada usuario tiene asignado un termina!; 
desde éste puede acceder a los recursos 
del sistema al ordenar que se ejecute 
cierto comando o programa. 
Cuando se activan varios programas a la 
vez (operación multitarea), el sistema ope- 
rativo se encargará de organizar la com- 
partición del tiempo de acceso a la CPU 
entre ios diversos procesos demandan- 
tes, de acuerdo a su prioridad; desde 
luego, los distintos procesos compartirán 
de igual forma los dispositivos periféricos 
asociados al sistema. 

EL CONCEPTO DE PROCESO 



El concepto de programa como un con- 
junto de códigos ejecutables, aislados y 
autos uficien tes, queda obsoleto en el ám- 
bito del MP/M. En general, los programas 
necesitan i.nteraccíonar con el sistema 
operativo para establecer comunicación y 
operar con los distintos periféricos. Así 
pues, un proceso no es simplemente un 
bíoque estático de código ejecutable, sino 
que además de Ja propia ejecución def 
código del programa debe gobernar la eje- 
cución del código del sistema operativo 
requerido por el programa, pasando, así, a 
trabajar de una forma esencialmente di- 
námica. 

Los procesos se generan al ejecutar una 
carga mediante el comando LOAD para 



crear un fichero objeto; automáticamente, 

se asocia un proceso al nuevo programa 

ejecutable que acaba de ser creado. Por 

consiguiente, es el proceso en vez del 

programa el que controla los accesos a los 

diversos recursos del sistema 

En el marco del MP/M se consideran tres 

categorías de programas: 

—Programas CP/M, 

— Procesos propios del sistema. 

— Procesos residentes del sistema o "Re- 

sident System Processes" (RSP). 

La primera categoría engloba a programas 

CP/M clásicos, que una vez cargados e 

inicial izados son asociados a un proceso 

sobre el que actuará el MP/M. La segunda 

incluye a aquellos procesos que realizan 

las tareas del sistema operativo; por 

ejemplo, al Intérprete de Comandos de 




Atendiendo a la naturaleza de las fundones 
que tienen asignados, el MP¡M se divide en 
tres módulos: XfOS, XDOS y BDOS. 



Unes CLI (del inglés JJ Command Line In- 
terprete^ '), cuya misión es cargare inicia- 
Jízar los programas de los usuarios. La úl- 
tima categoría está integrada por proce- 
sos que pueden ser integrados opcional- 
mente en la generación 'del sistema. Este 
tercer grupo permite la inclusión de pro- 
cesos escritos por el usuario; procesos 
que pueden paliar alguna carencia o adap- 
tar más perfectamente el sistema opera- 
tivo originalmente suministrado. 

DESCRIPCION FUNCIONAL 
DEL MP/M 



Uno de los principales objetivos en el di- 
seño del sistema operativo MP/M, fue lo- 
grar la compatibilidad con el software ya 
desarrollado para CP/M. De ahí que la es- 
tructura de los diversos módulos que 
componen el sistema operativo multíu- 
suario sea muy parecida a la propia de los 
módulos del CP/M, Así pues, más que 
diferencias reales, ios módulos del MP/M 
coinciden con ampliaciones adecuadas 
para contemplar las nuevas funciones in- 
troducidas. 

Funcionalmente, el MP/M está com- 
puesto por tres módulos: 
—Sistema operativo de disco básico o Ba- 
sic Disk Operating System (BDOS). 
— Sistema operativo de disco ampliado o 
Extended Disk Operating System (XDOS). 
— Sistema operativo de entrada-salida 
ampliado o Extended l/O System (XI OS). 




El acceso a ios dispositivos periféricos comunes al sistema se canaliza por medio de 
interrupciones. Estas dan prioridad al usuario que primero solicite el recurso, excluyendo 
momentáneamente a los restantes procesos que invoquen al periférico en cuestión. 
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EL MODULO BDOS 




RESTAURAR 

ESTADO 
PROCESOS 




CPU 




ACTUALIZA 
DESCRIPTOR 
FTOCESOS 



El acceso de los distintos 
procesos a la CPU está 
regulado por ei ' distribuidor''. 
Este se encarga de seleccionar 
aí proceso de mayor prioridad, 
que será ejecutado hasta que se 
produzca una interrupción. 



Este módulo contiene las funciones lógi- 
cas para la gestión de ficheros en disco 
y para el gobierno de las distintas consolas 
o terminales. Es compatible con la versión 
monousuarío. Ello significa que, en la ma- 
yor parte de los casos, pueden ejecutarse 
programas que hacen llamadas al módulo 
BDOS del CP/M sin tener que modificar- 
los. No obstante, el módulo BDOS está 
ampliado respecto a la versión monousua- 
rio; una ampliación con dos objetivos bási- 
cos: hacer frente a ios accesos múltiples 
que se producen en los archivos cuando 
se actúa en un entorno multi usuario, y 
llegar a soportar el uso de múltiples panta- 
llas y dispositivos de presentación. 



EL MODULO XDOS 



Su misión es proporcionar al sistema ope- 
rativo MP/VI las herramientas adecuadas 
para gestionar la posibilidad de mu Iti pro- 
gramación. Dentro de este módulo caben 
tres zonas funcionales; el núcleo lógico 
del sistema que se encarga de supervisar 
la ejecución de los diferentes procesos 
que compiten por la CPU y los recursos 
del sistema; las diversas ampliaciones re- 
feridas a las funciones de getión de fiche- 
ros y, por último, las utilidades necesarias 
para leer los comandos del usuario y eje- 
cutar los programas que correspondan. 
Dentro del núcleo lógico del sistema se 
distinguen varios submódulos, entre los 
que destaca el distribuidor de procesos. 
La transferencia de los recursos de la CPU 
de un proceso a otro corre a cargo de una 
parte del núcleo denominada distribuidor. 
Esta se encarga de asignar el tiempo de 
disfrute de la CPU a cada proceso, en 
base a una estructura de datos, asociada a 
zeda proceso, llamada descriptor de pro- 
cesos. El descriptor de un proceso con- 
dene las características propias del mismo 
y es utilizado por el distribuidor para apun- 
xar cómo quedó un proceso al agotarse su 
Tiempo de acceso a la. CPU, o para exami- 



nar el estado de un proceso que va a 
empezar a consumir tiempo de CPU, 
Los posibles estados de un proceso son 
tres: 

— Preparado o esperando para utilizar la 
CPU. 

— En ejecución o consumiendo recursos 
de la CPU. 

— Suspendido o aguardando para acceder 
a algún recurso del sistema distinto de la 
CPU, □ por efecto de algún aconteci- 
miento particular. 

Así pues, el distribuidor va permitiendo el 
acceso a la CPU de acuerdo a la prioridad 
indicada en el descriptor de procesos, 
hasta que se produzca la interrupción y le 
llegue el turno al siguiente proceso de 
superior prioridad, Este método de trabajo 
implica que siempre debe existir un pro- 
ceso en ejecución; al respecto, el sistema 
mantiene "en observación" a un proceso 
(IDLE process), con una prioridad muy 
baja, que se ejecutará siempre que no 
haya otro proceso activo. 



GESTION DE COLAS 



La comunicación entre los distintos proce- 
sos, el sincronismo de su ejecución y la 
exclusión mutua entre procesos, son ta- 
reas que se pueden llevar a cabo po- 
niendo en práctica una estructura especial 
de datos llamada cola. Esta estructura es 
similar a un fichero de disco, aunque con 
la particularidad de que siempre reside en 
la memoria central. Sobre ella se puede 
actuar de forma análoga aun fichero con- 
vencional: se puede abrir, cerrar, leer, es- 
cribir y borrar. 

En las colas, los procesos pueden leer o 
escribir mensajes de dos formas: condicio- 
nal o incondicional Si un proceso efectúa 
una lectura incondicional de una cola va- 
cía, el proceso en cuestión queda suspen- 
dido, pasando a una cola especial [De- 
quene List), hasta que otro proceso es- 
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El nexo entre el usuario y los comandos residentes en la unidad central, se estable ve a través 
del "'procesador de mensajes del terminal * ílMP) y del 'intérprete de comandos de línea' 
(CLl). 



criba en dicha cola. Análogamente, si un 
proceso trata de escribir en una cofa llena, 
éste se verá suspendido, pasando a otra 
cola especial (Enquene List), hasta- que 
quede sitio libre para realizar fa escritura. 
El MP/M utiliza estas dos colas especia- 
Jes, en la forma indicada, para lograr la 
sincronización de los procesos. Si Ja lec- 
tura o escritura se realiza de forma condi- 
cional, los procesos no pasarán a las refe- 
ridas colas especiales, sino que el sistema 
generará un mensaje de error cuando no 
es posible efectuar la operación. La exclu- 
sión mutua de dos procesos se gestiona 
mediante colas cuyo nombre empieza por 
Ja letra MX y en cuyo interior Jos mensajes 
tienen una longitud nula; de esta forma se 
garantiza el acceso de un solo proceso a 
un recurso determinado para evitar posi- 
bles conflictos. 



GESTION DE BANDERAS 



El núcleo lógico del MP/M utiliza banderas 
o indicadores lógicos para señalar o sin- 
cronizar procesos según haya ocurrido un 
proceso o no. Estas banderas permiten al 
sistema generar interrupciones físicas 
que se producen desde el hardware e in- 
teraccionan con la parte física de la má- 
quina. Hay que tener en cuenta que tales 
indicadores están especialmente diseña- 
das para interaccronar con el hardware, de 
ahí que no sea conveniente utilizarlos en 
aplicaciones software, salvo que se tenga 
un gran conocimiento de su implicación o 
sea estrictamente necesario; en general, 



la comunicación y el sincronismo entre 
procesos se resuelve mejor mediante la 
técnica de colas. 



GESTION DEL TIEMPO 



La exacta contabilización del tiempo por 
parte del sistema operativo MP/M, nece- 
saria para su correcto funcionamiento, 
está en manos de dos procesos del sis- 
tema: TICKy CLOCK. 
El primero de ellos, TICK, reactivado cada 
20 milisegundos, determina el tiempo de 
acceso a la CPU permitido para cada pro- 
ceso activo. La frecuencia de reactivación 
no es aconsejable que sea muy elevada, 
puesto que se perdería mucho tiempo 
guardando y restaurando proceses que 
abandonan y retoman el acceso a la CPU. 
No obstante, tampoco es conveniente 
que sea muy baja, ya que un proceso po- 
dría adueñarse de la CPU durante un largo 
periodo y paralizar a los restantes. 
El segundo proceso del sistema, especia- 
fizado en este cometido, es CLOCK. Este 
es activado cada segundo y su función es 
la de mantener e ir incrementando la fe- 
cha; de esta forma el sistema tiene un 
conocimiento inmediato y constante del 
año, mes, día, hora, minuto y segundo en 
curso. 

Con estas funciones, el sistema es capaz 
de ofrecer la fecha, retardar la ejecución 
de procesos un determinado período de 
tiempo y regular un programa para que se 
cargue desde el disco y se ejecute en un 
preciso instante. 



LA COMUNICACION CON 
LAS CONSOLAS 



En el MP/M!, cada consola tiene asociado 
un proceso de mensajes del terminal, 
TMP (del inglés "Terminal Message Pro- 
cess"), numerados del 0 al 15 y asignados 
a cada terminal en el instante de generar 
el sistema; su presencia permite soportar 
las líneas de comandos aceptadas por 
cada terminal. 

Este proceso, al igual que cualquier otro, 
tiene su descriptor de proceso, localizado 
en et segmento TMPD. DAT, y su código 
único para cada TMP (código reentrante] 
reside en el módulo ejecutable TMP.SPR. 
El propio sistema operativo se encarga de 
mantener los buffers, pilas y variables lo- 
cales necesarias para cada TMP. 
El TMP puede leer comandos tanto del 
terminal como de unos ficheros especia- 
les de tipo SUB, residentes en disco, y 
que contienen las distintas líneas de co- 
mandos. Una vez leído el comando, el 
TMP asigna la consola a otro proceso Ha- 
mado intérprete de lineas de comandos, 
CLl ("Command Line Interpreter"). En 
ese instante, el CLl toma el control del 
terminal, interpreta el comando y activa el 
programa transitorio o programa resi- 
dente del sistema (RSP) requerido. Tras la 
ejecución del referido programa, el CLl 
devuelvé él control de la pantalla al TMP. 



EL MODULO XIOS 



El módulo XiOS no es más que una exten- 
sión del BIOS del CP/M, cuyo objetivo es 
hacer frente a las capacidades de multi ter- 
minal y multiprogramacíón del MP/M. 
Como es lógico, vaha de uno a otro mo- 
delo de ordenador; hay que tener en 
cuenta que este módulo incluye progra- 
mas específicos que sirven de mero nexo 
entre la parte lógica y el entorno material 
(hardware), y éste suele cambiar de un 
fabricante a otro. 

Las principales funciones que realiza el 
XIOS son: manejo de los puertos o acce- 
sos para comunicación serie y paralelo, 
tratamiento de las interrupciones, acceso 
a disco y gestión de tiempos. 
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Aplicaciones 



Hojas electrónicas 

La solución informática a los problemas 
de "lápiz, papel y calculadora" 



xísten muchas aplicaciones 
que tradícionalmente han es- 
tado apartadas de la trayecto- 
ria hacia la mecanización. 
Por ejemplo, a nivel personal, el control de 
pagos a cofegios o la contabilización de 
ingresos laborales, y a nivel empresarial, 
la planificación financiera o la optimización 
de resultados. 

Cuando alguien pensaba en confeccionar 
un programa para ordenador destinado a 
resolver alguna de las aplicaciones señala- 
das, acababa, generalmente, desechando 
la idea, ya que fos métodos empleados 
eran (o podían ser) distintos dia a día. Los 
datos manejados eran personales y a ve- 
ces confidenciales, y el volumen de infor- 
mación no era demasido grande. Si em- 
oargo, al sumar los datos manejados en 
varias ocasiones, su volumen podía llegar 
a resultar considerable. En definitiva, a 
este tipo de problemas se les denomina 
"de lápiz, papel y calculadora". 



ORIGEN DE LAS HOJAS 
ELECTRONICAS 



En la Universidad de Harward se consi- 
deró la posibilidad de desarrollar una apli- 
cación informática capaz de resolver cual- 
quiera de los problemas de lápiz r papel y 
calculadora. Evidentemente, para que el pro- 
grama fuera bien aceptado debía ser muy 
. ersátil, de forma que no se limitara a un 
campo de actuación exclusivo. Sólo sus 
ituros usuarios debían ser los encarga- 
os de buscar aplicaciones concretas al 
programa. Otra cualidad exigióle era su 
sencillez de uso. El usuario medio del pro- 
"ucto no sería un especialista en Informá- 
tica, y su nivel de conocimientos podía ser 
muy diverso. 




Tradhionnlmente. muchos problemas han 
estado reservados para su resolución 
manual, a base de lápiz, papei y calculadora. 
Coa i a creación de las hojas electrónicas, 
son muy numerosas las aplicaciones de esta 
categoría que han pasado a manos del 
o rden a do r pe rso t i al . 

Bob Frankston y Dan Brickon, en San José 
de California, llegaron a desarrollar una 
aplicación que denominaron VISICALC. 
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La hoja electrónica constituye una 
herramienta idónea para solucionar 
problemas numéricos, resueltos hasta ahora 
a base de tabular columnas de datos en una 
retícula de papel, establecer relaciones 
matemáticas entre ios datos y evaluar los 
resultados con una calculadora. 

Esta reunía todas las exigencias anterio- 
res. A nivel comercial la idea resultó tan 
brillante que a los pocos meses de su 




En la alternativa informática, la función que desempeñaba el lápiz pasa a quedar en manos del 
teclado; a su vez, el papei se ve sustituido por la pantalla y la calculadora por la perfecta 
coordinación de ía aplicación de hoja electrónica y el ordenador. 
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Aplicaciones 




OPERADOR 



lanzamiento formaron una empresa con el 
único objetivo de mantener y distribuir su 
aplicación. Posteriormente, surgieron mu- 
chos productos símifares r hasta Ifegara la 
gran variedad de aplicaciones semejantes 
que se encuentran en el mercado actual. 
Como ya se ha apuntado, una de las ca- 
racterísticas más importantes de los pro- 
blemas que se pretenden resolver con 
este tipo de aplicaciones, es que los usua- 
rios no quieren verse "atrapados" por un 
modelo rígido. De hecho, cabía suponer 
que no habían optado mecanizaciones 
particularizadas por no perder la libertad 
de que disponían trabajando sobre una 
hoja de papel. 

Intentando resaltar esta cualidad y bus- 
cando un nombre comercial pegadizo y 
competitivo, este software de aplicación 
fue bautizado como: Hojas Electrónicas. 
Los resultados de aplicar este producto a 
ordenadores personales han sido tan ópti- 
mos que, en la actualidad, muchas de las 



Planificación financiera, evaluación de 
modelos económicos, análisis de vos íes. 
prepárele ion de ofertas <.<> todas ellas son 
actividades cuya resolución puede 
acometerse con el apoyo de una hoja 
electrónica. 



DIRECTIVO 





d 


i 


o. 




0 




RESUMEN 





ORDENADOR 
PERSONAL 




Un ejemplo típico de transferencia de información, para su posterior tratamiento por medio de 
una hoja electrónica. El gran ordenador envía un resumen de la facturación de la empresa a 
un ordenador personal; adoptando una hoja electrónic a como herramienta de trabajo, el 
directivo estará en condiciones de utilizar el ordenador personal para elaborar análisis 
económicos y emitir informes al respecto. 



aplicaciones de planificación, que tradicio- 
nalmente se explotaban en grandes orde- 
nadores, han pasado a resolverse cómo- 
damente con un microordenador y la co- 
rrespondiente hoja electrónica. Con la 
ventaja adicional de que los directivos de 
la empresa son usuarios finales del pro- 
ducto, no dependiendo, por lo tanto, más 
que de su propia capacidad de gestión 
para tomar las decisiones sobre el cauce 
que debe seguir su empresa. 

¿EN QUE CONSISTE UNA HOJA 
ELECTRONICA? 



• 



Desde el punto de vista físico, una hoja 
electrónica es un programa o paquete de 
programas dedicado a resolver problemas 
del siguiente tipo: 

• Planificaciones financieras de merca- 
do, de personal, etc. 

• Gestión de procesos de fabricación 
Seguimiento de costos. 
Preparación de ofertas. 
Estadísticas diversas. 

• Y otras muy diversas. 
Normalmente, estos programas se ejecu- 
tan en ordenadores personales, aunque 
también es posible explotarlos en minior- 
denado res e incluso en g randes ordena- 
dores. La tendencia actual en empresas 
de tipo medio o grande, consiste en ma- 
nejar Jos datos operativos de la empresa 
mediante aplicaciones tradicionales de 
gestión, en ordenadores grandes; y una 
vez procesados todos los datos, transmitir 
un resumen significativo de los datos ma- 
nejados aun ordenador personal, para que 
en ese momento la dirección de Ja em- 
presa pueda manejar cómoda y rápida- 
mente esa información resumida, ya sea 
mediante hojas electrónicas, procesado- 
res de texto... 

Un ejemplo típico de este tipo de proce- 
sos puede ser el siguiente: supóngase 
una aplicación tradicional de facturación 
de servicios a clientes, que maneje un 
gran volumen de información. El producto 
final de esta aplicación serán las facturas 
propiamente dichas y un resumen de fac-. 
turación que puede incluir, entre otras co- 
sas, facturación por cliente, facturación 
por producto, facturación por empleado, 
etc, Estos resúmenes no deben ser está- 
ticos, ya que en determinado momento 
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En el ejemplo de hoja electrónica que aparece en la figura de ta izquierda, los datos de ¡ÚS 
cas iílas D2, D3 v D4 t se habrán definido, respectivamente, por medio de las siguientes 
fórmalas: (B2*C2), (B3*C3) y (B4*C4), A su vez, como dato de la celda D5 (suma total de los 
importes) se habrá especificado ta fórmala íD2 + D3-\-D4}, 

En la figura de ía derecha* la pantalla muestra la naturaleza de los distintos elementos de la 
hoja electrónica utilizada en el ejemplo anterior. 



puede surgir la necesidad de hacer opera- 
ciones con los datos de distintos resúme- 
nes; éste es el punto en el que entra en 



escena la hoja electrónica. La forma idea! 
ele acometer estos nuevos estudios es 
mediante un ordenador personal, al que 



se le ha hecho llegar la información resu- 
mida. 

Desde el punto de vista lógico, una hoja 
electrónica es una gran matriz con filas nu- 
meradas (1 r 2 r 3, ...) y columnas [denomi- 
nadas A, B r C r „.), De tal forma que cada 
uno de los elementos de la hoja viene 
definido por un número que identifica la 
fila en la que se encuentra, y por una letra, 
con la que se determina su respectiva co- 
lumna. El sistema de designación es simi- 
lar al utilizado en el popular juego de los 
barcos: una retícula con las casi Las identi- 
ficadas por el cruce de fila y columna. 
Cada uno de los elementos de la matriz u 
hoja electrónica puede ser de tres tipos: 

—literales alfabéticos que servirán única- 
' rúente para realizar descripciones de otros 
elementos de la hoja electrónica. 

— Datos numéricos que pueden ser utílí- 



Elementos de las hojas electrónicas 



Al igual que cualquier otro programa o 
paquete de aplicación, la explotación de 
una hoja electrónica exige la concurrencia 
de un determinado número de elementos 
hardware y software. Elementos que en su 
expresión mínima se detallan en los 
siguientes apartados. 

• Elementos hardware 

La configuración física del equipo necesario 
para el empleo de una hoja electrónica, es 
la que cabe denominar "configuración 
típica". Esta consta de un procesador o 
unidad central, una unidad o periférico de 
entrada/salida y, opción al mente, alguna 
unidad de almacenamiento. Como 
procesador puede servir cualquiera de los 
que dan naturaleza a un ordenador 
personal. La unidad de entrada/salida 
coincide con un terminal o con la pantalla y 
el teclado propios del ordenador personal; 
mientras que el periférico de 
almacenamiento puede ser una unidad de 
disco o de cinta magnética. 
Así como en los tratamientos de textos 
resultaba de vital importancia la 
colaboración de una impresora, en el caso 
de las hojas electrónicas, aun siendo de gran 
interés, no constituye un elemento 
imprescindible, puesto que su frecuencia 
de utilización sera netamente inferior. 

• Elementos software 

A lo largo de la obra se estudiarán con 
detállenlas principales aplicaciones 
informátk:as-'de la hoja electrónica. La 
mayor parte de ellas se basan en 
programas redactados en lenguaje máquina 



con objeto de aumentar la velocidad de 
ejecución. Es fundamental que los 
programas sean rápidos, ya que cada vez 
que el usuario realice una modificación en 
cualquiera de los elementos de 3a matriz, 
ello implicará recalcular todos los 
elementos que contengan fórmulas que, a 



su vez, incluyan como argumento el 
elemento modificado. 
Obviamente, los programas de hoja 
electrónica no sólo tienen que gestionar 
datos sino que, fundamentalmente, deben 
estar especializados en realizar cálculos de 
distinto tipo. 




Elementos necesarios para el trabajo con hojas electrónicas. Tal como se observa en la 
figura, éstos se reducen a una configuración hardware —constituida por el ordenador 
personal, la unidad de almacenamiento (disco) y la impresora — , complementada con el 
paquete de aplicación al efecto. 
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Si el rama ño de la hoja electrónica excede a 
las dimensiones de la pa m alia, esta última 
áci uará como una ventana, capaz de 
desplazarse a través de la superficie de la 
hoja y visualizar el contenido de cada 
fragmento. 



zados para representar la información nu- 
mérica manejada. 

— Fórmulas de cálculo que manejarán los 
datos numéricos de la hoja para producir 
resultados. 

De esta forma, cuando eJ usuario intro- 
duce o modifica el contenido de un f ¡te ral 
alfabético, el programa se limita a almace- 
nar la descripción introducida. En cambio, 
cuando se introduce o modifica un ele- 
mento numérico, o una fórmula de cál- 
culo, el programa se encargará de recalcu- 
lar de forma automática todos los elemen- 
tos relacionados. Evidentemente, taf posi- 
bilidad de recálculo convierte a estos pro- 
gramas en poderosas herramientas de 
trabajo para muy diversos tipos de proble- 
mas. 



FUNCIONAMIENTO DE UNA HOJA 
ELECTRONICA 



Para poder ejecutar el programa de aplica- 
ción se debe preparar el disco flexible, la 
cinta magnética o cualquier otro soporte 
físico en el que se encuentre almacenado 
el programa. A continuación, utilizando el 
comando de carga del sistema operativo 
que gobierne al ordenador, hay que intro- 
ducir el programa en la memoria principal. 
Af ejecutarlo, aparecerá en la pantalla una 
representación en forma de retícula o ma- 
triz de casillas, en la que fas filas aparece- 
rán numeradas y las columnas se identifi- 
carán mediante letras. Para desplazarse a 
través de Jos elementos de la matriz, el 
usuario controlará el movimiento def cur- 
sor que, inicia Imente, aparecerá situado 
en ef elemento A-1 ; esto es: en fa casilla 
definida por la intersección de la primera 
fila y la primera columna. 
A continuación, ya sea mediante las te- 
clas de desplazamiento del cursor (arriba, 
abajo, derecha o izquierda), o bien me- 
diante algún comando del programa, éste 
puede conseguir que el cursor se posi- 
cione en la casilfa deseada. 
Una vez situado convenientemente el cur- 
sor, será preciso teclear ef dato que se 
desee introducir en el elemento corres- 
pondiente de la matriz: 
— Un literal alfabético. 
— Un dato numérico. 
—Una fórmula de cálculo. 
Estos últimos elementos, una vez definí- 
dos, tomarán el valor que resulte de eje- 
cutar fas operaciones indicadas en la fór- 
mula a partir de los datos numéricos pre- 
viamente introducidos. Los cálculos co- 
rrespondientes a una fórmula no sólo se 




La unidad de 
almacenamiento 
asociada al 
ordenador 
personal no sólo 
está destinada a 
almacenar el 
programa de 
aplicación: 
también el 
c ontenido de las 
hojas 

electrónicas 
elaboradas puede 
ser memorlzado 
en un soporte 
externo para su 
posterior 
re utilización. 



realizan en ef momento de su introduc- 
ción, sino que serán recalcu lados por ei 
programa cada vez que se modifique al- 
guno de sus parámetros; desde luego 
siempre que el usuario así lo decida. 
Existen muchos y muy diversos formatos 
para la representación en pantafla de los 
elementos de la matriz que da cuerpo a la 
hoja electrónica: formato científico, for- 
mato entero, formato ajustado a la dere- 
cha, formato ajustado a la izquierda, etc. 
El usuario decide siempre cuáf es el for- 
mato con que se desea trabajar 
Dado que el tamaño de la pantalla es limi- 
tado, tanto para filas como para columnas, 
el programa permite utilizar la pantalla a 
modo de ventana: ésta va desplazándose 
sobre la hoja electrónica y va mostrando 
distintas porciones de la misma. De esta 
forma, el movimiento del cursor siempre 
será refativo al movimiento de la ventana 
dentro de la hoja. 

Medíante la combinación de ambos movi- 
mientos (ventana y cursor), el usuario 
puede examinar todo el contenido de la 
hoja electrónica, antes de proceder a su 
escritura en una impresora o a su almace- 
namiento en un soporte de memoria 
(cinta, disco, ...). Por supuesto, no es im- 
prescindible terminar una sesión de tra- 
bajo con la impresión o almacenamiento 
de la hoja electrónica. En muchos casos 
— manteniendo fa analogía del programa 
con el papel, lápiz y máquina de calcufar— , 
los resultados obtenidos sólo servirán 
para tomar una decisión, y el usuario ter- 
minará rompiendo el papel (corresponde a 
finalizar la ejecución sin almacenamiento 
ni impresión). En otros casos, una vez ter- 
minados los cálculos, interesa preservar el 
papel con los resultados para archivarlo, 
utilizarlo o incluso para enviárselo a un 
tercero (corresponde a finafízación sin al- 
macenamiento, pero con impresión). Y, 
por último, es posible que el usuario 
quiera conservar la hoja de papel con fos 
datos y resultados para volver a utilizarla 
en otra ocasión (corresponde a finalización 
con almacenamiento e impresión). 
Prácticamente, todos los fabricantes de 
ordenadores personales ofrecen, dentro 
de su catáfogo de software de aplicación, 
una hoja electrónica de cálculo. En los tres 
próximos capítufos se estudiará detenida- 
mente fas características de la primera y 
tal vez más importante de las hojas elec- 
trónicas: VISICALC. Más adelante, en 
esta misma sección de la obra se repasarán 
las características técnicas de otros pro- 
ductos informáticos similares. 
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La práctica del BASIC 

El programa: un puzzle 

organizado de comandos e instrucciones 



odo curso de programación ha 
de tener su zona práctica; sin 
lugar a dudas "el movimiento 
se demuestra andando". 
En los capítulos anteriores se han introdu- 
cido los primeros conceptos teóricos del 
enguaje BASIC y ha tenido lugar la pre- 
sentación de un buen número de coman- 
dos. Descripciones que se han acompa- 
ñado de una amplía variedad de ejemplos 
ilustrativos. 

En el presente capítulo, inclinado hacía la 
vertiente práctica, se van a ensamblar las 
□iezas del puzzle de conceptos, coman- 
dos e instrucciones descritos hasta este 
□unto de la obra. Para ello se van a propo- 
ner algunos problemas y se va a acome- 
ter, paso a paso, su resolución progra- 
mada. 

BORRADO DE LA PANTALLA 



Antes de entrar en materia es necesario 
presentar un nuevo comando BASIC que 
'esultará de inapreciable utilidad a lo largo 
del capítulo. Se trata del comando CLS 
2 Lear Screen), cuya ejecución se traduce 
en el borrado del contenido de la pantalla, 
devolviendo al cursor al principio de la 
misma, 

CLS no incorpora argumento alguno y, 
normalmente, se puede ejecutar tanto en 
modo directo como indirecto. Algunos or- 
denadores disponen incluso de una tecla 
especial destinada a su introducción in- 
mediata. La mencionada tecla puede lie- 
zar la inscripción CLEAR/HOME u otra si- 
milar. 

Desgraciadamente, el borrado de pantalla 
_ : se ajusta a una formulación estándar 



en la mayoría de los ordenadores. Las al- 
ternativas son varias. 
Generalmente, los equipos que no dispo- 
nen de CLS, utilizan una instrucción, 
PRINT para ese mismo cometido. Aque- 
llos que admiten caracteres de control den- 
tro del argumento PRINT, suelen adoptar la 
siguiente formulación: 
PRINT "<tecla de borrado de pantalla >" 
A su vez, los ordenadores cuyo dialecto 
BASIC no admite la inclusión de dichos 
caracteres, o que no poseen una tecla 
específica de borrado, suelen utilizar la si- 
guiente instrucción PRINT: 
PRINT CHR$ (<num>). 



CLS 






CALCULA LA 
DESVIACION MEDIA 
DE UNA POBLACION 



La calidad de ía presentación en pantalla condiciona drásticamente el atractivo e incluso ía 
eficacia práctica de un programa* Una muestra palpable la ofrece eí simple cartel descriptivo 
que aparece en ía figura. 




Borra la pantalla posicionando el cursor en la esquina superior izquierda. 

Formato: (Número de línea) CLS 

Ejemplos: CLS 

20 CLS 
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PROGRAMA A 

10REM SOFTWARE/CARTEL 
1000 CLS 
1010 PRINT 
1 020 PRINT 
1030 PRINT"* 

1040 PRINT "C3§ PROGRAMA 
1050 PRINT"* 
1060 PRINT"* 
1070 PRINT"* 
1080 PRINT"* 
1090 PRINT"* 
1100 PRINT "* 
1110 PRINT"* 
1120 PRINT "* MEDIA DE UNAPOBLACIÜN *" 
1130 PRINT "* 

1140 PRINT "* *" 
1150 PRINT "* ESCRITA POR: *" 
1160 PRINT"* *" 
1170 PRINT"* *JUAN PEREZ * *" 

1180 PRINT"* 
1 1 90 PRINT 



^ 5f! SJt S(t ^ 3f¡ sfc:JcJ¡4 ijt l(t ^ 

* ESTADISTIK * 

;fc 5fc* £ # Dfc * # # * 



CALCULA l_A DESVIACION 



La primera herramienta a esgrimir será le 
versátii instrucción PRINT; imprescindible 
para Ja escritura de mensajes en la pan- 
talla. 

Como primer ejemplo se diseñará un car- 
tel de entrada a un programa BASIC, en el 
que aparecerá el nombre del programa y 
algunos datos de interés. Este constituiré 
la zona inicial de un programa adecuada 
para resolver algunos cálculos estadís- 
ticos. 

A lo largo de este ejercicio se va a trabajar 
con una pantalla capaz de visualizar 20 
filas de 30 caracteres cada una. Por su- 
puesto, en el caso de que el ordenador 
trabajara con una mayor resolución, habrá 
que adecuar el ejemplo ampliando las di- 
mensiones del cartel. 
La primera alternativa aJ alcance del pro- 
gramador se reduce a utilizar directa- 
mente un bloque de instrucciones PRINT. 
Por ejemplo: 



10 REM SOFTWARE/CARTEL 
100 PRINT "PROGRAMA" 
110 PRINT "ESTADISTIK" 
120 PRINT "CALCULA LA DESVIACION" 
130 PRINT 'MEDIA DE UNA POBLACION" 
140 PRINT "ESCRITO POR:" 
150 PRINT "JUAN PEREZ" 



Una primera solución programada para la creación de un cartel en ía pantalla del ordenador. 



En donde <num> es un número entero 
específico que coincide con el código de 
borrado de pantalla (normalmente 26), Por 
último, existen máquinas que no aportan 
ninguna instrucción para el borrado de 
pantalla. En estos casos se hace necesa- 
rio borrarla "manualmente"; por ejemplo, 




*** 



La confección del cartel resultará más 
cómoda si el usuario recurre a las 
herramientas que brinda el lenguaje BASIC. 
Por ejemplo, el trazado de las fdas de 
asteriscos puede encomendarse a un bucle 
t ORIN EXT, en el que se introducirán sendas 
instrucciones del tipo PRINT AT* 



ejecutando tantos comandos PRINT sin 
argumento, como líneas tenga la pantalla. 
Desde luego, el camino apropiado en cada 
caso conduce a revisar el manual del orde- 
nador para conocer el método que adopta. 

DISEÑO DE UN CARTEL 



Una de las facetas que determinan fa cali- 
dad de un programa es, sin lugar a dudas, 
su presentación. Algunos programadores 
pasan por alto la vertiente estética, pres- 
tando exclusivamente su atención a la ve- 
locidad de ejecución o a la exactitud de los 
datos. Desde luego que éste es un obje- 
tivo ineludible, si bien, el programa alcan- 
zará una mayor calidad y perfección con 
una presentación esmerada y agradable. 
Ello hará incluso que resulte más atractivo 
y relajado el trabajo con los ordenadores. 



El cartel creado al ejecutar esta rutina re- 
sulta muy poco espectacular; aunque 
tampoco el esfuerzo del programador ha 
sido excesivo. Su representación en la 
pantalla es una muestra elocuente de efi- 
cacia huérfana de todo condimento esté- 
tico: 



RUN 



PROGRAMA 
ESTADISTIK 

CALCULA LA DESVIACION 
MEDIA DE UNA POBLACION 
ESCRITO POR: 
JUAN PEREZ 



Un primer detalle disto rsionador fo repre- 
senta la presencia de la orden RUN en la 
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pantalla. Esta no forma parte del cartel y, 
por lo tanto, no debe aparecer. La solución 
es muy simple y consiste en incluir una 
línea de borrado de pantalla cuya ejecu- 
ción se superponga a la palabra RUN. Con 
ello se eliminará cualquier carácter visuali- 
zado en la línea en cuestión. 
Otro punto a mejorar es la distribución^, 
general del texto. Para darle una mayor 
simetría, pueden colocarse las frases cen- 
tradas en la pantalla. Desde luego, tam- 
bién es posible darle una mayor vistosidad 
encerrando el cartel dentro de un recua- 
dro confeccionado con asteriscos. Su 
nuevo aspecto es el que refleja la figura 
adjunta (programa A). 
Su presentación resulta bastante más 
atractiva. De hecho, en el listado aparece 
el texto distribuido tal y como ha de salir 
en la pantalla. El único problema radica en 
el trabajo adicional que ello exige. Mien- 
tras que la primera rutina tenía sólo siete 
líneas, la actual contiene veintiuna (justo 
el triple). Esto puede hacer que el progra- 
mador cambie de opinión respecto a la 
estética del resultado, Pero casi todo 
tiene solución en el BASIC; veamos hasta 
qué punto es posible compatibilizar una 
ouena presentación con una programa- 
ción cómoda. 

Una de las zonas de la segunda rutina 
■programa A) que resultan de más incó- 
moda introducción es el marco de asteris- 
cos. Esta es una tarea perfectamente en- 
comendare al ordenador... ¿No es un ver- 
dadero experto en ejecutar tareas reitera- 
tivas? Para ello haremos uso de la instruc- 
ción FOR/NEXT. 

En principio, la línea 1020 del programa A 
se puede sustituir por el siguiente bloque 
de instrucciones: 

1020 PRINT ""; 

1021 FOR 1=1 T0 28 

1022 PRÍNT 

1023 NEXTI 

Idéntico tratamiento puede darse a la línea 
1 190. Con lo cual, el usuario se ve liberado 
de Ja necesidad de introducir a mano dos 
filas de asteriscos. El precio a pagar son 
seis líneas más de programa. 
Aún cabe mayor comodidad. Por medio 
de la variante AT del comando PRINT, se 
puede colocar el texto sin necesidad de 
teclear espacios en blanco. Así, por ejem- 
plo, la línea 1040 puede adoptar esta 
nueva formulación: 

!040 PRINT AT(12,4); "PROGRAMA" 

Esta característica del comando PRINT 




El medio adecuado para ordenar eí horrado de la pantalla difiere de uno a otro ordenador. 
Algunos modelos incorporan eí comando CLS, otros recurren a una formulación especial de la 
instrucción PRINT, e incluso hay equipos que poseen una tecla especifica para tal cometido. 




1300 PRINT AT(1 2,4); "PROGRAMA" 
1310 PRINT ATÍ107); ÍJ *E$TADI$TfK*'' 
1320 PRINT AT(5, 10); "CALCULA LA 

DESVIACION" 
1330 PRÍNT AT(5,12};"ME0IA DE UNA 

POBLACION" 
1340 PRINT AT(5,1 5) ¡"ESCRITO POR" 
1350 PRINT AT(J3,17);"*JUAN PEREZ*" 




Programa para dibujar un cartel en la pantalla. La nueva variante de programa incorpora las 
facilidades descritas en el texto. Estas harán que sea el propio ordenador quien se ocupe de 
dibujar las lineas de cierre , así como de colocar el texto en ¡as zonas previstas de la pantalla. 
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INSTRUCCIONES 
PARA 
UTILIZAR 
CORRECTAMENTE 
EL PROGRAMA 



PULSE JJ S" PARA 
CONTINUAR 



La presencia 
de carteles o 
mensajes 
resulta de 
gran interés, 
particular- 
mente en ios 
programas 
cuya 

complejidad 
exigiría al 
usuario 
consultar con 
frecuencia el 
folleto de 
instrucciones. 





también permitirá dibujar rápidamente el 
recuadro; por ejemplo, la fila superior de 
asteriscos: 

1020 F0RX=2 TO 29 
102? PRINT AT(X, 2); "*" 

1022 PRINT AT(X, 19); "*" 

1023 NEXTX 

El mismo método puede utilizarse para 
dibujar las dos columnas de asteriscos la- 
terales, e incluso para el trazado del marco 
interior que encierra ef nombre del pro- 
grama. Por supuesto, en el resto del cartel 
se seguirá utilizando el comando PRINT 
AT para situar el texto en el lugar ade- 
cuado. Con las nuevas facilidades aporta- 
das por el PRINT AT, se llega a una nueva 
redacción del programa original. Su as- 
pecto (programa B) es el que muestra la 
correspondiente figura. 
La nueva rutina es bastante más dilatada 
que la solución original, si bien, no cabe 
duda que ello ha repercutido en beneficio 
de la presentación del programa. Y, desde 
luego, un programa no se puede conside- 
rar acabado sin que se haya contemplado 
la visualización estética de los datos. 

UN PEQUEÑO TRUCO 



El APL funciona 
en d.os modos: 
^JPQfto calculadora 





La calidad de un programa no depende exclusivamente de su precisión, potencia y velocidad 
de ejecución. También la vertiente estética contribuye a elevar su eficacia, logrando que el uso 
del programa resulte más cómodo y agradable para el usuario. 




Cuando los mensajes 
son extensos y no caben 
en una simple pantalla, 
es preciso recurrir a 
algún medio que permita 
detener la visualización 
en el punto adecuado. 
De lo contrario, el texto 
del cartel se desplazará 
vertiginosamente a 
través de la pantalla, 
imposibilitando su 
lectura. 



La presencia de los carteles puede resul- 
tar muy importante en ciertas ocasiones. 
Un ejemplo claro lo proporcionan aquellos 
programas que, por su complejidad, obli- 
gan al usuario a conocer las instrucciones 
o normas de funcionamiento. Estas nor- 
mas suelen editarse aparte, en el ade- 
cuado folleto o manual, aunque también 
pueden formar parte del programa. Una 
buena costumbre es incluirlas en el pro- 
grama. Las normas e instrucciones de 
uso pueden visualizarse por medio de 
carteles, semejantes al diseñado. De 
esta forma, el usuario puede examinarlas 
mientras se ejecuta el programa y, al 
tiempo, se evita la distorsión que supon- 
dría la pérdida del folleto que las contiene. 
Cuando es preciso visualizar varios carte- 
les seguidos, surge un problema: ¿cómo 
detener la ejecución del programa mien- 
tras el usuario está leyendo el cartel? De 
no interrumpir la secuencia de ejecución, 
ías pantallas irían pasando muy rápida- 
mente por la pantalla, imposibilitando su 
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El código ASCII 



Para que e! ordenador pueda manipular 
internamente las letras del alfabeto y los 
números y signos especíales, es preciso 
que éstas adopten una forma especial de 
representación. No hay que perder de 
vista que los circuitos internos del 
ordenador sólo pueden trabajar en código 
binario: con secuencias de ceros y unos. 
Estos ceros y unos "traducidos ' a 
códigos decimales, aparecerán como 
números representativos de los distintos 
caracteres alfabéticos y numéricos. Esta 
correspondencia hará posible que la 
máquina pueda manipular correctamente 
los números y palabras que se 
introduzcan de acuerdo a dicha 
codificación. 

Evidentemente existen innumerables 
posibilidades de codificación (tantas como 
cabe imaginar). Cada usuario puede crear, 
incluso, su propio código personal para la 
representación de los caracteres. 
Sin lugar a dudas, los códigos personales 
no resultan útiles en orden a compartir la 
información representada con otros 
equipos. De ahí que se intentaran unificar 
los criterios, con el objetivo de establecer 
un sistema de representación 
generalizado Son varios los códigos para 
la representación binaria que gozan de 
aceptación general: por ejemplo, el 
denominado EBCDIC o el código 
BAUDOT. Sin embargo, el código más 
umversalmente aceptado es el que 
responde a las siglas ASCII {American 
standard code for mformation 
i n te re ha ng e : cód i go está nda r am e ri ca no 
para el intercambio de información). 

El código ASCII representa cada carácter 

§or medio de un único byte (ocho bits) r 
e ahí que sus posibilidades de 
codificación se eleven a 2=256 caracteres 
distintos. Este número resulta más que 
suficiente para codificar las letras, cifras y 
símbolos de uso más frecuente. De ahí 
que en la práctica acostumbre a reducirse 
el rango de codificación. Al respecto, la 
longitud de cada palabra binaria ASCII 
suele reducirse a siete bits, lo que 
permite representar a un total de 
128 caracteres; número éste más que 
suficiente en las tareas habituales. 
Algunos ordenadores reservan algún 
cometido específico para el octavo bit 
libre. Normalmente, lo utilizan para 
conseguir un juego de caracteres 
alternativo o un repertorio de caracteres 
gráficos específicos de la máquina. 
En la tabla adjunta aparece relacionado el 
código ASCII de siete bits. La codificación 



de cada carácter aparece en expresión 
decimal (base 10}, hexadecimal (base 16), 
octal (base 8] y binaria. Por ejemplo, el 
dígito cero tiene asignado el código ASCII 
001 1000 (48 en expresión decimal) y [os 
nueve siguientes códigos en orden 
creciente, corresponden a la 



representación ASCII de las restantes 
cifras decimales. El abecedario en 
mayúsculas está ordenado entre los 
códigos 65 y 90 y el de minúsculas entre 
los códigos 97 y 122. Los restantes 
códigos representan caracteres especiales 
como, por ejemplo: (, $, ?, ", # 



CODIGO ASCII 



CA- 


CODIGO 






CA- 


CODIGO 








RAC- 










DEFINICION 


RAC 










DEFINICION 


















TER 


BINARIO DEC.HEX.OCF 




TER 


BINAHIO L>EC HFX. OCT. 




NUL 


nono nnnn 




00 


'•¡re 


NuÍq 


t 


niño nnr>n 

LT 1 UU UUUU 


64 


40 


100' 


"AEpersand" 


SOH 


nnnn nnni 

UUUU UUU 1 




01 


rjj' 


Pmopto de encabezamiento 


A 




65 


41 


10T 




STX 


0000 00 1 0 


2 


02 


ZZ2 


Comienzo de texto 


B 


OÍ00 0010 


€5 


42 


102 




ETX 


onnn nni i 




03 


--- 


Fm de texto 


C 


Q10G 001 1 


67 


43 


103 




EOT 


oooo nmn 

UUUU UF7Jl_r 


4 


04 


■ ■ .: 


Rn de transmisión 


D 


ntoo mfXJ 


6S 


44 


104 




ENQ 




g 


06 


005 




E 




69 


45 


105 




ACK 




3 


06 


JÓ6 


Acuse de reabo 


F 


nmn ni i n 


70 


46 


106 




BFL 


nnnn finí 


7 


07 


?f 7 


Trrnbre feeñaf) 


G 


nmn oí 1 1 


71 


47 


107 




BS 


nnñn mññ 


:^ 


08 




Retroceso 


H 


nmn mnn 

U 1 UU 1 UUU 


72 


48 


1 10 




HT 


nnnn inni 

UUUU 1 UU 1 


9 


09 


01 1 


Tabulación horizontal 


1 


nmn mni 

U 1 UU \\i\í 1 


73 


49 


Til 




LF 


nnnn mm 

UUUU 1 U 1 U 


10 


0A 


012 


Camino de renglón 


J 


nmn mm 

U 1 UU 1 \J h u 


74 


4A 


112 




VT 


nnnn i ni i 

UUUU 1 U 1 1 


1 1 


DB 


- * - 


Tabulación horizontal 


K 


ni i'ií 1 1 n 1 1 

U 1 OU l\f t 1 


?h 


4B 


1 1 3 




FF 


nnnn 1 1 nn 

UUUU I I UU 


J 2 


OC 


014 


Pág»na siguiente 


L 


ni nn i inn 

U 1 UU 1 1 UU 


76 


4C 


1 T4 




CR 


nnnn 1 1 m 

UUUU MUI 


- 3 


0D 


015 


Retroceso de carro 


M 


nmn 1 im 

\J 1 UU 1 1 U 1 l 


77 


4D 


- 




SO 


nnnn 1 1 1 n 

UUUU 1 1 1 U 


; ¿ 


0E 


Z ' z 


F^era de código 


N 


oí nn 1 1 1 n 

V 1 UU 1 1 IV 


7B 


4E 


• io 




SI 


nnnn 1 1 1 1 

UUUU lili 


1 5 


0F 




2 " z-z-z zz 


O 


nmn 1 1 1 1 

U 1 UU lili 


79 


4F 


- - 7 




DLE 


nnm nono 


1 ñ 


10 


Z2Z 


Ercsje de transmisión 


P 


G 1 0 ! 0000 


80 


60 


120 




DC1 


noni orn- 

UUU 1 UUTJ ! 


"¡7 


11 


■- - - 


Mando de dispositivo auxi- 
liar i 


O 


nmi nnm 

1./ 1 LJ 1 UUU 1 


ñ 1 


61 


121 




DC2 


noni nnm 

\J\JlJ 1 UU 1 u 


ig 


12 


022 


Mando de despositivo auxi- 
liar 2 


R 


0101 0010 


62 


52 


122 




DC3 


onni nni i 


1 í; 


13 


023 


1 Mandó de dispositivo auxi- 
a- 2. 


S 


n i r • no 1 1 

U 1 U 1 O-J 1 1 


33 


53 


123 




DC4 


nr if vi n i r ) 

UUU 1 U 1 UU 


20 


14 


024 


\'2~zz re z E2DS"tivo au>\\- 

fiar 4 


T 


01 01 01 00 


B4 


64 


124 




MAK 


0001 0101 


21 


15 


;:5 


Acuse de recibo negativo 


U 


0101 0101 


85 


55 


125 




SYISí 


000 1 0 1 l 0 


22 


16 


02 E 


5 Zzz. zr. ze reboso 


V 


0101 0110 


86 


56 


126 




£TB 


0001 0111 


23 


17 


027 


fin de bloque oe transmisión 


,, 


0101 01 n 


87 


57 


127 




CAN 


0001 1000 


24 


18 


030 


Cancelación 


X 


0101 1000 


88 


58 


130 




EM 


0001 1001 


25 


19 


031 


- ' C~ ™-3" Z ; ÍS¡CO 


Y 


0101 1001 


39 


59 


131 




SUB 


0001 1010 


25 


1A 


032 


Sustitución 




a loi íoio 


90 


5A 


132 




ESC 


0001 1011 


27 


1B 


033 


Escape 


[ 


0101 1011 


91 


5B 


133 


Apertura' de corchete 


FS 


0001 1 100 


28 


1C 


034 


r ¿-:-7.-z'%z\z' :ie : ::n?'o 


\ 


010! 1100 


92 


5C 


134 


Barra invertida ("Back 


GS 


0001 1101 


29 


ID 


035 


Sepa/ador de grupo 


] 


0101 1101 


33 


SD 


135 


Cierre de corchete 


RS 


0001 1110 


20 


1E 


036 


Separador de registro 




01 DI IT 10 


94 


5E 


136 


Acento circunflejo 


US 


000T 1111 


31 


1F 


037 


Separador de unidad 




0101 1111 


05 


5F 


137 


Güión de subrayada 




0010 0000 


32 


20 


040 


Espacio en blanco 




0110 0000 


96 


60 


140 


Acento inverso 


1 


0010 0001 


33 


21 


041 


Admiración 


a 


0110 0001 


97 


ei 


141 






0010 0010 


24 


22 


042 


Comilfas 


b 


0110 0010 


98 


62 


142 




# 


0010 0011 


35 


23 


043 


Símbolo número 


c 


0110 0011 


99 


63 


143 




s 


0010 0100 


35 


24 


044 


Símbolo dólar 


d 


0110 01 00 


100 


64 


144 




% 


0010 0101 


37 


25 


045 


Porcentaje 


e 


0110 0101 


101 


65 


145 




& 


0010 0110 


3í3 


26 


046 


"Ámpersand" 


f 


OnO Ono 


102 


66 


146 






0010 011 1 


33 


27 


047 


Acento 




0110 0111 


103 


67 


147 




{ 


0010 1000 


¿G 


28 


050 


Apertura de paréntesis 


h 


0110 1000 


1 ÚA 


66 


150 






0010 1001 


¿i 


29 


051 


Cierre de paréntesis 


i 


0110 1001 


105 


69 


151 






0010 1010 


¿2 


2A 


052 


Asterisco 


J 


0110 1010 


106 


6A 


152 




+ 


0010 1011 


43 


2B 


053 


Signo más 


k 


0110 1011 


107 


6B 


153 






0010 1100 


44 


2C 


054 


Coma 


i 


ono neo 


IOS 


GC 


154 






ODIO 1101 


45 


2D 


055 


Guión (signo menos) 


m 


0110 1101 


109 


6D 


155 






0010 1110 


46 


2E 


056 


Punió 


n 


0110 1110 


110 


6E 


156 




/ 


0010 1111 


■i' 


2F 


057 


Símbolo división ("slash") 


o 


0110 1111 


111 


6F 


157 




0 


001 1 0000 


¿8 


30 


060 




P 


01 1 1 oooo 


I 12 


70 


160 




1 


0011 0001 


49 


31 


061 




q 


01 1 1 0001 


113 


71 


161 




2 


0011 0010 


bO 


32 


062 




r 


01 11 0010 


114 


72 


162 




3 


0011 0011 


51 


33 


063 




s 


0111 001 T 


115 


72 


163 




4 


0011 0100 


52 


34 


064 




t 


0111 0100 


116 


74 


164 




5 


0011 0101 


53 


35 


065 




u 


01 1 1 0101 


■ a 


75 


165 




6 


0011 ono 


h'. 


36 


066 




V 


01U 0110 


118 


76 


166 




7 


0011 0111 


5 b 


37 


067 




w 


0111 0111 


119 


77 


167 




S 


0011 1000 


56 


38 


070 




X 


0111 1000 


120 


78 


170 




9 


0011 1001 


57 


39 


071 




y 


0111 1001 


121 


79 


171 






0011 1010 


5o 


3A 


072 


Dos punios 


L 


0111 1010 


122 


7A 


172 






0011 1011 


63 


3B 


073 


Punto y coma 


< 


on ion 


123 


7B 


173 


Apertura de corchete 


< 


0011 1100 


60 


3C 


074 


Menor que 


1 


0111 1100 


124 


7C 




Barra vertical 




00 11 1101 


61 


3D 


075 


Igual 


> 


oí n i íoi 


125 


7D 


175 


Cierre de corchete 


> 


0011 1110 


62 


3E 


076 


Mayor que 




0111 1110 


126 


7E 


176 


Tilde 




001 1 1111 


63 


3F 


077 


Interrogante 


DEL 


0111 1111 


127 


71 


177 


Borrado, supresión 



DEC. = Decimal. HEX. = Hexadec¡mal. OCT = Octal 
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Basic 



PANTALLA 1 




INPUT " PULSE RETURN 
PARA CONTINUAR "j A$ 



PULSE RETURN PARA 
CONTINUAR 



SI 



PANTALLA 2 



Una solución cómoda y útil para fragmentar fa visualizaron ¿le carteles en sucesivas 
pantallas, la constituye el empleo de un "falso INPUT' . Ai ejecutarlo, el ordenador detiene la 
visual izacíón , presentando el mensaje asociada y aguardando a que el usuario accione alguna 
tecla para pasar a la siguiente pantalla. 



Sí se desea situar el mensaje en un punto 
determinado de la pantalla, habrá que utili- 
zar previamente una instrucción de tipo 
PRINT AT. En nuestro ejemplo será sufi- 
ciente con añadir las dos líneas siguientes 
para que quede contemplada la referida 
posibilidad: 

1340 PRINT AT(2, 20); 
H00 INPUT "PULSE RETURN PARA 
CONTINUARIAS 

La línea 1390 obliga a que el mensaje que 
acompaña a INPUT se imprima a partir de 
la posición señalada por el argumento de 
AT. Con ello, es posible colocar el men- 
saje en el punto deseado y no en la línea 
siguiente a la utilizada por el último PRINT. 

DE LA ESTADISTICA AL JUEGO 



lectura. Una posible solución fa aporta el 
comando STOP; en efecto, su especiali- 
dad no es otra que detener la ejecución. 
En tal caso, bastaría con introducir un co- 
mando CONT para reanudarla. Para evitar 
la necesidad de teclear tantas letras (cua- 
tro de la palabra CONT más la tecla RE- 
TURN) existen varios "trucos". Por ejem- 
plo, el BASJC dispone de algunas funcio- 
nes que permiten detectar una pulsación 
en el teclado, pero esta solución es aún 




El lenguaje BASIC ofrece herramientas 
adecuadas para el trabajo en la pantalla del 
ordenador. Herramientas que permiten 
visualizar mensajes y construir 
presentaciones a voluntad del programador. 



prematura, ya que de ellas se hablará en 
posteriores capítulos. 
Los conocimientos adquiridos en capítu- 
los anteriores son suficientes para dar con 
una solución. El truco consiste en recurrir 
a un "falso INPUT", Cabe recordar que 
dicha instrucción detiene la ejecución del 
programa hasta que se introduce un dato 
a través del teclado. Así pues, bastará con 
pedir al usuario que introduzca un dato 
cuando haya terminado de leer el cartel. 
Esta solución no resulta excesivamente 
elegante, ya que la introducción de un 
dato cuando es [relevante, puede dar lu- 
gar a confusiones. Por lo tanto, enmasca- 
raremos al INPUT, pidiendo tan sólo la 
pulsación de la tecla RETURN, Esta sería, 
en definitiva, la línea a incluir tras las que 
corresponden a la visual ización del cartel: 

1400 INPUT "PULSE RETURN PARA 
CONTINUARIAS 

Su presencia hará que el ordenador inte- 
rrumpa et programa, cuya ejecución rea- 
nudará cuando el usuario pulse la tecla 
RETURN. 

La coma localizada detrás del mensaje 
evita que la pantalla muestre el signo de 
interrogación característico de INPUT. Al 
pulsar Ja tecla RETURN sin haber introdu- 
cido previamente dato alguno, la variable 
AS no recibirá la asignación de valor al- 
guno y, en consecuencia, quedará "va- 
cía". Ello no supone ningún problema, 
sino que basta, simplemente, con ignorar 
dicha variable. 



El ordenador representa una gran ayuda 
para el trabajo y la investigación dado su 
gran poder de cálculo. Su capacidad ma- 
temática también puede utilizarse para 
otra finalidad más lúdica; para el ocio, por 
ejemplo. A través de este apartado van a 
conjugarse fas posibilidades matemáticas 
y lúdicas del ordenador de la mano de un 
programa. 

El juego consiste en simular el lanza- 
miento de un proyectil, con la precisión 
adecuada para acertar en el blanco. Para 
elfo, se suministrarán a la máquina la velo- 
cidad inicial y eJ ángulo de disparo. 
El programa se reduce a la resolución ma- 
temática de un tiro parabólico. La ecua- 
ción de partida es Ja siguiente: 

S=V0*T+(1/2)*A*t|2 

La velocidad inicial (VO) se separa en sus 
dos componentes según las direcciones 
vertical y horizontal. Para ello, se hará uso 
de los datos iniciales (velocidad "VO" y 
ángulo "AJMG") y de las dos ecuaciones 
que siguen: 

VOx=V0*COS(ANG) 
VOy=V0*SEN(ANG) 

Los referidos datos permiten calcular la 
distancia alcanzada por el proyectil sin 
más que introducirlos en la ecuación ini- 
cial: 
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O 10 20 30 40 50 60 




VELOCIDAD INICIAL 
Vo 



ANGULO 
DE TIRO 




na nzj lzzd i 



lj=u 



Escenario del juego creado por el programa "Tiro parabólico". El jugador debe acertar en el 
blanco, seleccionando la velocidad inicial del proyectil y et ángulo de tiro con la precisión 
adecuada > 



Q-V0y-(1/2)*G*T 
Sx=V0x ii T 

(G es la aceleración de la gravedad, cuyo 
valor es de 9,81 m/s). 

Con estos conocimientos se está ya en 
disposición de crear el cuerpo o zona prin- 
cipal del programa. 

200 LET G=9,81 
210 LETVX=V0*C0$ÍANG) 
220 LET VY=VO*SIN(ANGÍ 
230 LET T=(VY*2}/G 
240 LET SX=VX*T 

La tarea realizada ha sido convertir las 
ecuaciones matemáticas a líneas de pro- 
grama en lenguaje BASIC. Pero estas li- 
neas no funcionan por sí solas, sino que 
55 necesario introducir los datos inicíales: 
velocidad inicial y ángulo del proyectil. 
Esto se logra por medio de un par de 
nstru ce iones JNPUT: 

110 INPUT "VELOCIDAD INICIAL";V0 
120 INPUT "ANGULO DE TIR0";ANG 



Cualquier ordenador suele trabajar, nor- 
malmente, con ángulos expresados en ra- 
dianes. Por lo tanto, el dato a introducir en 
la línea 120 debe ser el número de radia- 
nes deseado. Si al usuario le resulta más 
cómodo utilizar grados, es necesario que 
teclee estas otras dos líneas, adecuadas 
para la conversión de grados a radianes: 

130 LET Pl =3 1416 

140 LET ANG-{ANG*PI)/180 

El próximo paso consiste en detectar si 
se ha producido un impacto en el blanco. 
En primer lugar hay que situar el blanco en 
una posición fija. Por ejemplo, a una dis- 
tancia de 500 metros del punto del lanza- 
miento dei proyectil. Se supondrá, asi- 
mismo, que e! btanco mide 10 metros de 
largo. Ello significa que se considerará 
acertado si la distancia SX a la que im- 
pacta el proyectil está comprendida entre 
495 y 505. 

Si al calcular SX se obtiene un valor supe- 
rior a 505, se habrá errado el tiro por ex- 
ceso. En tal caso, el ordenador debe indi- 



TABLA DE 
CONVERSION 


ORDENADOR 


CLS 


CLS 


APPLE II 
(APPLESOFT) 


CALL-936 


APRICOT 
(M-BASIC) 


PRINT CHR$ (26) 


ATAñl 


PRINT " V 


CBM 64 


PRINT "S" 


DRAGON 


CLS 


EQUIPOS MSX 


CLS 


HP-150 


— 


IBM PC 


CLS 


MPF 


HOME 


NCR DM-V 
(MS-BASIC) 


PRINT CHfll (26) 


NEW BRAIN 




ORIC 


CLS 


SHARP MZ-700 
(MZ-BASIC) 


print 'mr 

PRINT CHR$ (6) 


SINCLAIR QL 


CLS 


SPECTRA VIDEO 


CLS 


ZX-SPECTRUM 


CLS 



car a qué distancia del blanco cayó el pro- 
yectil. Algo parecido ocurre cuando SX 
toma un vaior inferior a 495, con la salve- 
dad de que el error en el tiro será por 
defecto. 

Una vez programada, la zona para la de- 
tección de la eficacia del tiro adoptará el 
siguiente aspecto. 

300 IF SX>505 THEN GOTO 400 
310 IF SX<495 THEN GOTO 500 
320 PRIJMT "BLANCO" 
330 END 

400 PRIJMT "DISTANC!A= ,r ;SX 
410 PRINT "FALLO P0R r ';SX-5G0 
420 GOTO 100 

500 PRINT "DISTANCIA=";SX 
510 PRINT "FALLO POR";500-SX 
520 GOTO 100 
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Basic 



PROGRAMA 



10 REM TIRO PARABOLICO 
20 FOR 1=1 TO 5 

100 PRINT "OBJETIVO A 500 METROS" 

110 INPUT "VELOCIDAD INiCIAL";VO 

120 INPUT "ANGULO DE TIRO"; ANG 

130 LET Pl =3.1416 

140 LET ANG=(ANG*PI)/180 

200 LET G =9.81 

210 LETVX=VO*COS{ANG) 

220 LETVY=VO*SINfANG) 

230 LET T=(VY*2)/G 

240 LET SX=VX*T 

300 IF SX>505 THEN GOTO 400 

310 IF SX<495 THEN GOTO 500 

320 PRINT "BLANCO" 

330 ENO 

400 PRINT "DISTANCIA=";SX 
410 PRINT "FALLO POR"; SX-500; 

"METROS" 
420 GOTO 600 

500 PRINT "DISTAN CIA =";SX 
510 PRINT "FALLO POR"; 50O-SX; 

"METROS" 
600 NEXT l 

610 PRINT "NO HA CONSEGUIDO" 
620 PRINT "DESTRUIR EL OBJETIVO" 
700 END 







O 

o 
o 
o 
o 

o 
o 
o 



r 



ERROR 

POR DEFECTO 



I 



495 
_J 




1 500 | 



505 



ERROR 
POR EXCESO 



OBJETIVO A 500 METROS 
VELOCíDAD INICIAL? 20 
ANGULO DE TIRO ? 45 I 



El programa considera que la longitud del blanco es de diez metros. En consecuencia, 
resultará eficaz cualquier disparo cuyo impacto se produzca a una distancia de 495 a 505 
metros del origen del proyectil. 



En la línea 100 es conveniente colocar un 
mensaje que indique la distancia a la que 
se encuentra el objetivo. 

100 PRINT "OBJETIVO A 500 METROS" 

Por último, y para dar mayor emoción al 
juego, se limitará el número de disparos 
realizables. Para ello r se introducirá la ru- 
tina dentro de un bucle FOR/NEXT, La 
variable del bucle (I) irá contabilizando el 
número de disparos efectuados. En el 
ejemplo, se dispone de cinco oportunida- 
des (límite de la variable FOR}. 
El programa, completado con la incorpora- 
ción de las últimas condiciones enuncia- 
das, coincide con el que aparece en la 
figura adjunta (programa C). 
La ejecución del programa se traduce en 
la presentación en pantalla que aparece a 
continuación. Los valores elegidos son 20 
metros por segundo para la velocidad ini- 
cial y un ángulo de salida del proyectil de 
25 grados. 



RUN 



OBJETIVO A 500 METROS 
VELOCIDAD INICIAL? 20 
ANGULO DE TIRO? 25 
DISTANCIA=31 .235247 
FALLO POR 468.76475 METROS 
OBJETIVO A 500 METROS 
VELOCIDAD INICIAL? ■ 




La petición de datos por parte del ordena- 
dor se repetirá en cinco ocasiones; por 
supuesto, siempre que el disparo no logre 
dar en el blanco, en cuyo caso se dará por 
terminado el programa en la línea 320. 
Si el jugador no consigue abatir al blanco 
enemigo, el programa finalizará mos- 
trando en la pantalla el siguiente mensaje: 



OBJETIVO A 500 METROS 
VELOCIDAD INICIAL? 75 
ANGULO DE TIRO? 45 
DISTANCIA -573.3945 
FALLO POR 73.3944% METROS 
NO HA CONSEGUIDO 
DESTRUIR EL OBJETIVO 
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Lenguajes 



Logo (9) 



TURTLE GRAPHICS 
la tortuga se multiplica 




pesar de la gran diversidad de 
posibilidades estudiadas hasta 
el momento, el método "turtle 
graphics" sigue encerrando 
nuevas funciones aún por desvelar. Fun- 
ciones que permiten un mayor control so- 
bre la tortuga, ya sea para establecer su 
velocidad de desplazamiento, o para mul- 
tiplicar su presencia en la pantalla. 

CONTROL DE LA VELOCIDAD 



Una de las características de la tortuga 
hasta ahora ignorada, es la posibilidad de 
alterar su velocidad de movimiento, Nue- 
tro disciplinado personaje no tiene por qué 
permanecer inmóvil, sino que puede lan- 
zarse a recorrer la pantalla con una deter- 
minada velocidad. El comando implicado 
es SETSP (SET SPeed). 
Por ejemplo, SETSP 20 hará que la tortuga 
camine con una velocidad de 20. Desde 
luego, su paseo no cesará hasta que se le 
asigne una velocidad cero. Si la tortuga se 
encuentra con la tiza "bajada", ésta irá 
dibujando su trayectoria sobre la pantalla. 
La orden SETSP no altera las restantes 
condiciones definidas, sino que mantiene 
los atributos correspondientes a posición, 
número y color de fa tiza. Cabe notar que 
la velocidad determina un movimiento 
rectilíneo en la dirección apuntada por el 
eje longitudinal de la tortuga. 
Es necesario significar las distintas reac- 
ciones de la tortuga dependiendo del 
modo en el que estén definidos los límites 
de la pantalla, Por ejemplo, si se ha selec- 
cionado el modo cerrado (con la orden 
WRAP), se verá a la tortuga aparecer por 
el punto opuesto a aquél por donde ha 




i 



El comando SETSP hace 
que la tortuga se mantenga 
en movimiento a ta 
velocidad especificada. El 
operador complementario es 
SPEED; su ejecución 
devuelve el valor de la 
velocidad de 
desplazamiento. 



J 



10 20 30 JS^ 50 



setsp 40 



abandonado la pantalla. En el caso de que 
la tortuga tuviera una orientación oblicua 
con respecto a los ejes de coordenadas, 
ésta no correría siempre, la misma línea 
diagonal. 

Cuando se opta por la pantalla de límites 
abiertos (WINDOW), la tortuga desapa- 
rece del campo visual y continúa avan- 
zando hasta llegar al final del terreno dis- 
ponible. La extensión de este terreno de- 
pende de la capacidad propia del ordena- 
dor Asimismo, las velocidades máxima y 
mínima admisibles vienen impuestas por 
las características del equipo. 
Como ya es habitual, el LOGO dispone de 
la función opuesta. EJ operador SPEED es 
el encargado de devolver el indicativo de 
Ja velocidad actual. El siguiente procedi- 
miento muestra la acción de las dos órde- 
nes presentadas. 




T0 EJEMPLO 
WRAP 

MAKE J A [ACELERA] 

CORRE 

END 



Como se observa, el procedimiento 
EJEMPLO incluye en su definición a dos 
procedimientos elementales, ACELERA y 
CORRE; a su vez, éste último engloba a 
un tercer procedimiento elemental: DE- 
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El LOGO permite el 
uso simultáneo de 
varias tortugas. 
Habitualmente , son 
cuatro las tortugas 
utiíizables; puro 
permitir su control, 
éstas se identifican 
por medh de un 
n úm ero compren dido 
entre cero y tres. 



FORWARD 
50 



La misión del comando TELL es definir qué tortugas van actuar a partir de ese instante. Tras 
llamar a dos tortugas — localizadas en distintos puntos de la pantalla o con distinta 
orientación — por medio del mencionado comando y ordenar un determinado movimiento, 
éstas ejecutarán el desplazamiento por distinta zona de la pantalla, de acuerdo a su posición y 
orientación de partida. 




? PRINT WHO 
2 

9 



WHO es un 
operador que 
revela el número 
de la tortuga "en 
curso" o tortuga 
llamada en 
última instancia. 
SI son varias las 
tortugas activas 
en el instante de 
hacer uso del 
mencionado 
operador, el 
ordenador 
mostrará los 
números de todas 
ellas. 



CELERA. Todos ellos aparecen definidos 
a continuación. 



TO CORRE 

IF SPEED>100 [MAKE' A [DECELERA] 
RUN :A 

IFSPEED<1 [STOP] 
[NO 



TO ACELERA 
SETSP SPEED+2 
END 

TO DECELERA 
SETSP S PEED -2 
END 

La ejecución del procedimiento EJEMPLO 
hará que la velocidad de la tortuga 
aumente de 0 a 100, en pasos de 2 unida- 
des. Al llegar a una velocidad mayor que 
100, la tortuga empezará a decelerar 
hasta que su velocidad vuelva a ser cero. 
Las instrucciones RUN e IF utilizadas en el 
procedimiento CORRE se describirán en 
un capítufo posterior dedicado al estudio 
de los bucles. 



DIBUJANDO CON VARIAS 
TORTUGAS 



Una sorpresa agradable la constituye el 
hecho de que la tortuga pueda también 
actuar en equipo. El LOGO permite traba- 
jar simultáneamente con más de una tor- 
tuga en escena. 

Habitualmente, el número máximo de tor- 
tugas es de cuatro, identificadas con los 
números del cero al tres. La tortuga con la 
que se ha trabajado hasta ahora es la nú- 
mero cero. Para que entren en juego las 
demás, es preciso "llamarlas" por medio 
del comando TELL (decir, "dile a" ..,), Este 
comando se emplea también para comu- 
nicar una orden a una tortuga específica. 
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Por ejemplo, TELL 1 hace aparecer a la 
tortuga número 1; a su vez, las órdenes 
que sigan serán obedecidas por la última 
tortuga invocada (en este caso, la número 1). 
Si se pretende que las órdenes afecten 
simultáneamente a varias tortugas, habrá 
que advertir de ello a los quelonios. Por 
ejemplo, para que las tortugas "actuantes" 
sean las dos primeras, habrá que empezar 
tecleando TELL [0 1} En general, es pre- 
ciso formar una lista con los números de 
las tortugas que deban obedecer al 
tiempo las mismas órdenes, y llamarlas 
con un comando TELL 
Las últimas tortugas invocadas con TELL 
se denominan tortugas en curso, por ser 
ellas las que obedecen las órdenes poste- 
riores. Si se invoca a varias tortugas situa- 
das en distintas posiciones de la pantalla, 
lo que se les mande dibujar lo ejecutarán 
todas ellas a la vez, aunque cada una en la 
zona que le corresponda. Cambiando de 
tortuga en curso, es posible controlar a 
cada una de ellas por separado. 
Para identificar a la tortuga o tortugas que 
están actuando en un determinado mo- 



mento, hay que hacer uso del operador 
WHO (quién). Su ejecución responde con 
el número de la tortuga o tortugas invoca- 
das en último lugar. Este operador resulta 
útil para dar órdenes distintas a cada tor- 
tuga. Por ejemplo, una instrucción del tipo 
FORWARD WHO* 10, hará que si la tor- 
tuga en curso es la uno, ésta avance 10 po- 
siciones, si es la dos, 20 ... 

TORTUGAS BAJO CONTROL 



Para dirigir a cada tortuga por separado se 
hace necesario llamarlas alternativa- 
mente. Ello se puede conseguir con el 
uso reiterado del comando TELL, o escri- 
biendo procedimientos que utilicen dicho 
comando. 

El siguiente ejemplo cambia la tortuga ac- 
tuante por la identificada por el siguiente 
número. 



0 


© 


j ó 




6-6 


TELL [0 1] 

PRINT WHO 

\m J 


EACH [SETXWHO*50] 










( ^ 




FORWARD 50 




PRINT WHO 








© 



T0 CAMBIAT0R 

IF WH0=3 [TELL 0] [TELL WH0+1] 
END 



Secuencia de pantallas que ilustra el efecto de las órdenes TELL, ASK y EACH. 



Cada vez que se ejecute el procedimiento 
cambiará Ja tortuga en curso. Con éste y 
otros procedimientos semejantes, el pro- 
gramador estará en condiciones de alterar 
la situación de las tortugas, para que cada 
una realice una tarea distinta. Existen tam- 
bién otros comandos que permiten una 
mayor flexibilidad en el uso de varias tor- 
tugas. Estos son los que se detallan a 
continuación. 

Cuando las órdenes a ejecutar por cada 
tortuga sean idénticas, se puede utilizar 
EACH (cada), La sintaxis de este comando 
es la siguiente: EACH <lista de instruccio- 
nes >. Por ejemplo, EACH [FORWARD 
200J hará que cada tortuga avance 200 
posiciones. La diferencia con ta situación 
normal consiste en que, ahora, la segunda 
tortuga no cursa la orden hasta que ter- 
mina de hacerlo la primera. De no utilizar 
el comando EACH, todas las tortugas 
"acatarían" la orden a la vez. 
La principal utilidad de EACH radica en su 
empleo conjunto con WHO. Tal combina- 
ción permitirá ejecutar órdenes distintas 
a cada tortuga; por supuesto, siempre que 
las órdenes se puedan reducir a una fun- 
ción del número de cada tortuga. 
Por ejemplo, para que cada tortuga gire en 
un ángulo de distinto número de grados, 
se puede introducir la orden; EACH 
[RIGHT WHO*90] Con el ejemplo apun- 
tado más arriba, en el que se utilizaba 
WHO sin EACH, se producirá un error si 
hay más de una tortuga en acción, simul- 
táneamente. Ello se debe a que WHO 
devuelve una lista de números. Sin em- 
bargo, cuando actúa en compañía de 
EACH, el LOGO se encarga de extraer de 
la lista cada número por separado. 
EACH no cambia la tortuga en curso y sólo 
actúa con las que estén disponibles en 
ese instante. 

El método adecuado para emplear una 
tortuga que no sea la actualmente en 
curso, sin por ello cambiarla, llega de la 
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mano de ASK. Este comando exige dos 
datos de entrada: el primero es el número 
de tortuga y el segundo la lista de las 
instrucciones que ha de "obedecer". Si se 
desea que las instrucciones las ejecuten 
varias tortugas, el primer dato debe ser 
una lista con los números de las tortugas 
afectadas. 

El siguiente ejemplo ¡lustra la actuación de 
cada comando. 



TELL [0 1] 
PRINT WHO 
0 í 




EACH [SETX WHÜ*50] 
ASK 2 [BACK 50] 
PRJNT WHO 

0 t 



Como se observa. ASK no altera las tortu- 
gas en curso. 

Otra posibilidad de ASK radica en su em- 
pleo como operador. Realmente, la acción 
de ASK es la que defina la lista de instruc- 
ciones que constituyen su dato de entrada. 
Ello significa que se comportará como un 
operador si la lista da un dato de salida. He 
aquí un ejemplo: 
PRINT ASK 1 [POS]. 

En este caso, las coordenadas de la tor- 
tuga 1 constituyen el dato de salida, a raíz 
de lo cual, ASK actúa como operador. 



TABLA DE ORDENES DEL 
"TURTLE GRAPHICS" 


Instrucción 


Cometido 


0 pe rador/coma ndo 


SETSP<número> 


Hace que la tortuga se mantenga en movimiento a la 
velocidad dada por <número> 


Comando 


SPEED 


Devuelve la velocidad actual de la tortuga 


r^ra rln r 


TELL<nu/lis> 


Define qué tortugas serán fas actuantes a partir de 
ese momento 


Comando 


WHO 


Devuelve una lista con los números de las tortugas 
en curso 


Operador 


EACH... < lista ; ns> 


Hace que las tortugas en curso ejecuten la lista de 
instrucciones, una tortuga después de otra 


Comando 


ASK<nu/1is> 
<íista ins> 


Hace que la o las tortugas especificadas ejecuten las 
instrucciones de la lista 


Ambos* 


SETC<número> 


Pone a la tortuga en curso del color indicado por 
<n0mero> 


Comando 


COLOR 


Devuelve el número que indica el color de la 
tortuga en curso 


Operador 



<nu/1is>: número de tortuga o lista de números de tortugas. 
< lista ins>: lista de instrucciones. 

* ASK se comporta como operador o comando dependiendo de la lista de instrucciones 



que lo acompañen. 



TORTUGAS DE COLORES 



Al igual que el fondo y las tizas, también 
las tortugas pueden cambiar de color. 





Ai igual que el fondo 
de la pantalla y las 
tizas de dibujo, 
también la tortuga 
puede adoptar varios 
colores. El comando 
al efecto es SETC< 
seguido por el 
n úmero 

correspondiente ai 
color seleccionado. 



Las instrucciones al efecto son SETC y 
COLOR. SETC, seguido por un número, 
otorgará a la tortuga o tortugas en curso el 
color especificado por dicho número. 
A su vez, el operador COLOR devuelve el 
número o código del color adoptado por 
las tortugas actualmente en uso. 
Ambas órdenes pueden asociarse tanto 
con EACH como con ASK. Una observa- 
ción a considerar es que el color de las 
tortugas es totalmente independiente de 
los colores elegidos para el fondo y las 
tizas. 

¿UNA 0 VARIAS? 



Todas las instrucciones presentadas para 
su ejecución con una sola tortuga pueden 
ser utilizadas con varias. Al respecto, sólo 
habrá que prever el uso de TELL, con lo 
que todas las tortugas en curso obedece- 
rán fas órdenes del programa. Cabe seña- 
lar también que por medio de ASK y 
EACH será posible diferenciar distintas ór- 
denes para cada tortuga. 
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Los comandos del MP/M 

Herramientas para el control 
de un entorno multiusuario 




e cara al usuario, el MP/M se 
comporta de forma análoga al 
sistema operativo CP/M; por 
supuesto, con la evidente dife- 
rencia de que permite que varios usuarios 
se encuentren conectados al mismo orde- 
nador, compartiendo los recursos de la 
CPU y la memoria y H en definitiva, mejo- 
rando eJ rendimiento de la instafación. Al 
igual que ocurría en ef caso deJ CP/M, ei 
sistema operativo MP/M ha de poner a 
disposición de los distintos usuarios toda 
una serie de herramientas que permitan 
gestionar el conjunto de datos almacena- 
dos en la memoria; algo sumamente im- 
portante en un sistema que permite el 
acceso simultáneo de hasta 16 usuarios. 
Además, por su propia naturaleza de sis- 
tema operativo multiusuario, el MP/M ha 
de brindar también los medios adecuados 



para el control de ios periféricos conecta- 
dos af ordenador (unidades de disco, im- 
presoras, ...). Estas herramientas deben 
proteger a Jos distintos periféricos del ac- 
ceso simultáneo de varios usuarios y, al 
tiempo, facilitar el acceso concurrente o 
secuencia! a los mismos. 
En definitiva, el sistema operativo ha de 
garantizar la correcta y eficaz explotación 
de fos recursos del equipo. 

LOS COMANDOS DEL MP/M 



A raíz de lo señalado en los párrafos ante- 
riores, es posible establecer una primera 
clasificación de ios comandos que el 



MP/M pone a disposición de los usuarios 
del sistema. 

• Comandos destinados a fa gestión in- 
terna y externa de los ficheros. 

Dentro de este grupo, y a modo de ejem- 
plo, cabe mencionar al editor (comando 
ED) o al comando PIP, el cual permite la 
copia de ficheros. 

• Comandos destinados af controi de ios 
periféricos 

En esta categoría caben comandos espe- 
cializados en la gestión y el control de los 
dispositivos auxiliares que apoyan !a acti- 
vidad del ordenador; por ejemplo, CON- 
SOLE y SPOOL 

• Comandos para ei controi de ios pro- 
gramas de aplicación que se encuentren 
activos en el ordenador. 

ATTACH, ABORT o SCHED son coman- 



A 



CONTROL - 



v 



CONTROL 



v 



[prograva: 

A 



¡programa: 

B 



[programa; 

c 



<3 



CONTROL- D 



v 



[programa; 
a 



¡.programa; 
b 



[programa; 



Cada ejecución del tomando CONTROL D libera a la consola del 
control de un programa. Una vez liberada, ésta puede pasar a 
controlar la ejecución de cualquier otro de ios programas que le 
resulten accesibles. 



La ejecución reiterada del comando CONTROL D da lugar a un 
proceso reversible. El ordenador irá devolviendo a la consola el 
control de los programas liberados por efecto de la ejecución previa 
del referido comando. 
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V 



.va: 



; programa; 

B 






La misión del comando ATTACH es devolver al terminal que lo activa 
el control de un proceso o programa desligado del mismo por efe vi o 
de ¡a orden CONTROL D, En este caso, la recuperación del control 
es selectiva, ya que permite elegir directamente cuál de los programas 
debe quedar de nuevo bajo control. 



El MPÍM dispone de un comando adecuado para forzar el abandono 
de la ejecución de un programa antes de que éste concluya por sí 
mismo; ABORT, En su argumento hay que incluir el número del 
terminal desde el que se activó el programa (consola 3 en el ejemplo}, 
así como el nombre del programa afectado. 



dos integrados en esta tercera categoría. 
En esta clasificación están integrados va- 
rios comandos que eJ MP/M comparte 
con su equivalente monousuario, el 
CP/M. Este es un hecho previsible dada la 
analogía que existe entre ambos sistemas 
operativos. De hecho, la mayor parte de 
Jos comandos incluidos en el primer grupo 
de la clasificación precedente, son co- 
mandos del CP/M. Desde luego, en algunos 
casos, presentan una sintaxis que difiere 
ligeramente. No hay que perder de vista 
que el ámbito de actuación del MP/M 
obliga a precisar detalles adicionales. Por 
ejemplo, debido a la multiplicidad de 
usuarios, pueden existir ficheros con el 
mismo nombre en usuarios diferentes, 
circunstancia que debe ser considerada 
en la sintaxis de ios comandos MP/M. 
Los comandos MP/Tvl pueden clasificarse, 
al igual que en el caso del CP/M, en co- 
mandos permanentes y transitorios Los 
comandos del primer tipo son aquellos 
que se cargan en la memoria del ordena- 
dor al mismo tiempo que el sistema ope- 
rativo. A su vez, los transitorios residen 
fuera de la memoria central; su traslado 
desde el disco a la memoria interna sólo 
se produce cuando el usuario invoca su 
ejecución. 

COMANDOS COMPATIBLES 
CP/M 



En efecto, la mayor parte de ios coman- 
dos del sistema operativo CP/M son utili- 



zabas en los equipos gobernados por el 
MP/M Los comandos compartidos de 
tipo permanente son introducidos en el 
ordenador en el momento de la carga, 
mientras que los transitorios han de apa- 
recer como ficheros del tipo PRL (Pro- 
gram Relogeable). Estos últimos son utili- 
zabas por todos los usuarios del sistema, 
Al ser invocados, se cargarán en uno de 
los segmentos de memoria reservados al 
usuario de quien procede la solicitud. 
El sistema operativo MP/M incorpora utili- 
dades para la transformación de ficheros 
que contengan comandos transitorios y 
no sean de tipo PRL. En efecto, pueden 
existir comandos con un formato inade- 
cuado, o que presenten díreccionamien- 
tos de memoria absolutos y no reiativos a 
los distintos segmentos en los que distri- 
buye la memoria el sistema operativo 
MP/M; ficheros cuya adecuación supone 
transformarlos a tipo PRL. 
Los comandos CP/M compatibles con el 
sistema operativo MP/M son los que se 
relacionan a continuación: 

Dffl ED 
ERA LOAD 
REN DDT 
TYPE SUBMIT 
STAT DUMP 
PÍP 

Hay que tener en cuenta que el formato 
que adopten en el MP/M no tiene por qué 
coincidir. Ello dependerá básicamente de 
la función que realicen y de su interacción 
con los restantes usuarios del sistema. 



COMANDOS PROPIOS 
DEL MP/M 



Dentro de los comandos propios del 
MP/M o que tienen una significación par- 
ticular del mismo, cabe establecer dos ca- 
tegorías; caracteres de control y coman- 
dos o utilidades suplementarios. 

• Caracteres de control 
Ef primer grupo engloba a las órdenes 
cuya introducción se realiza con una ac- 
ción simultánea sobre la tecla de control 
(CTRL) y una tecla alfabética. Su misión 
primordial consiste en el control de tos 
programas y procesos en curso de trata- 
miento por el ordenador. A continuación 
se definen los caracteres de control más 
relevantes 

CO NITRO L-S 

La función de esta orden es interrumpir el 
flujo de presentación de datos en el termi- 
nal del operador que lo solicite. Suspende 
temporalmente la presentación para que 
puedan examinarse los datos con comodi- 
dad. Para su introducción hay que accio- 
nar simultáneamente las teclas <CTRL> 

yS, 

CONTROL-Q 

Indica a la consola o terminal que puede rea- 
sumir el proceso de edición de datos por 
pantalla, interrumpido por efecto de un co- 
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mando CONTROL S. En el caso de pul- 
sar esta combinación inadvertidamente 
(<CTRL> y Q) no se produce ningún efecto 
pernicioso en el funcionamiento del orde- 
nador, ya que sólo es operativo cuando 
aparece interrumpido el proceso de edi- 
ción. 

CONTROL-D 

El comando CONTROL-D hace posible 
una de las facetas características del 
MP/M la multiprogramación desde una 
misma consola. Desde un mismo terminal 
puede ordenarse la ejecución de más de 
un programa. Una vez que el primer pro- 
grama ha recibido los datos necesarios 
para su operación, y se ha iniciado el pro- 
ceso de cálculo, es posible liberar la con- 
sola del mismo y ordenar la ejecución de 
un segundo programa. Este proceso 
puede repetirse sucesivamente hasta que 



todos los segmentos de memoria se en- 
cuentran asignados. 

Resulta evidente que esta facultad es útil 
cuando los programas en ejecución exi- 
gen constantemente recursos de CPU y 
no tienen interacción con el usuario más 
que en la introducción de datos y, tal vez, 
en la notificación de resultados. 
El proceso es reversible, de cara precisa- 
mente a permitir la interacción con el 
usuario, al introducir la orden CONTROL-D, 
El ordenador devuelve a fa consola eí con- 
trol de los programas, sí bien, el proceso 
de devolución tiene fugar en el mismo 
orden en el que los programas fueron libe- 
rados de dicho control. 

CONTROL-C 

Permite interrumpir la ejecución de un 
programa y liberar la zona de memoria 
que éste tiene reservada. Este comando 



puede emplearse también tras la activa- 
ción de una orden de interrupción det tipo 
CONTROL-S. 

Es importante señalar que aunque los ca- 
racteres de control son herramientas es- 
tandarizadas del sistema operativo MP/M, 
pueden existir programas que anulen su 
efecto y den vigencia a otras combinacio- 
nes específicas de la tecla CONTROL. Un 
ejemplo de elfo lo constituyen afgunos pro- 
gramas para el tratamiento de texto, 
como es el caso del WORDSTAR, 

• Comandos suplementarios y utilidades 
del MP/M 

Los más característicos son los que se 
relacionan a continuación, acompañados 
por una breve descripción de su funciona- 
miento. 

DIR (SYS) 

Su cometido es visualizar la lista de fiche- 



Proceso distribuido 



En la actualidad y debido al coste cada vez 
inferior de los microprocesadores y 
elementos de memoria, ha sido posible el 
nacimiento de una amplia variedad de 
microordenadores de distinta capacidad y 
potencia. A raíz de esta eclosión 
microinformática, cada día es mayor el 
número de usuarios que franquean el 
umbral de la automatización. Usuarios con 
unas necesidades específicas y cuya 
resolución exigen al equipo que obra a su 
disposición. 

En este punto, y con un efecto dilatado del 
margen de actuación de equipos con 
recursos limitados, nace el proceso 
distribuido. 

Partiendo de un grupo de ordenadores y H a 
través de un sistema de comunicación local 
o remoto, el proceso distribuido permite la 
puesta en común de recursos de los 
distintos equipos; de tal forma que cada 
uno de los ordenadores asociados tiene 
abierto el acceso a los recursos de los 
restantes equipos, tanto a nivel de 
programas como de ficheros de datos. 
Un ejemplo elocuente cabe encontrarlo en el 
seno de una gran corporación comercial. En 
ella, el ordenador que controla los 
resultados de los procesos de fabricación, 
está «nterconectado con el ordenador del 
departamento de ventas. Tal comunicación 
garantiza el acceso de este último a [os 
datos procesados en el primero, lo que 
permite una constante evaluación de las 
posibilidades comerciales de la compañía. 
El proceso distribuido aporta sustancíales 
ventajas, no siendo la menor de ellas el 
hecho de que cada usuario obtiene el 



máximo rendimiento de la máquina que 
está a su disposición, sin emplear más 
recursos que los estrictamente necesarios 
para su labor. Así, en el caso del ejemplo 
propuesto, el ordenador del departamento 



de ventas no necesita tener duplicada la 
información contenida en el de producción, 
con lo que su capacidad puede ser inferior y 
sin que ello degrade la respuesta que 
obtiene el usuario. 
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COMANDOS DEL MP/M 


Comando 




Significado 


D1R[SYS] 


Visualiza un directorio incluyendo ficheros de sistema. 


CONSOLE 


Indica número de consola. 


ERAQ 


Borrado de ficheros. 


DSKRESET 


Permite al usuario cambiar disquetes. 


GENHEX 


Genera un fichero hexadecimal de un fichero COM de CP/M. 


PRLCOM 


Genera un fichero COM de CPM a partir de un fichero PRL 


GENMOD 


Crea un fichero PRL de un fichero hexadecimal. 


SPOOL 


Envía un fichero a las colas de impresión. 


STOPSPRL 


Detiene la salida de impresión. 


TOD 


indica fecha y hora. 


SCHED 


Prepara una tarea para ejecutar a una hora fijada. 


ABORT 


Detiene la ejecución de un programa. 


ATTACH 


Devuelve el contra f de una tarea. 


PRINTER 


Selecciona la impresora a emplear. 


SET 


Indica estado del disco e introduce palabras de paso. 


SHOW 


Muestra estado del disco. 


MPMSTAT 


Estado del sistema operativo. 


SDIR 


Visual i zación del directorio. 



ros de un directorio, incluyendo a los fi- 
cheros del sistema o ficheros comunes a 
iodos los usuarios del equipo. Asimismo, 
permite la consulta del directorio de fiche- 
ros propio de cada usuario específico. 
El formato de esta orden es variable; de- 



pende de la versión del sistema operativo 
MP/M que se utilice. 

CONSOLE 

Permite consultar el número de la consola 
o terminal que está utilizando un determi- 



FICHERO A 



FICHERO B 




FICHERO C 



FICHERO D 



FICHERO E 



FICHERO F 




/ ¿ffVM^ /ff'.-V.'..^ 




/ 


o o o 


V 


y 



IMPRESORA 



En el ámbito del MPfM, 
los distintos usuarios 
pueden compartir una 
misma impresora 
asociada al sistema. La 
herramienta que permite 
ei uso concurrente de la 
misma la aporta el 
comando SPOOL; éste 
permite trasladar los 
archivos a imprimir a 
una "cola" de espera. 
La impresora ira dando 
curso a los distintos 
archivos de acuerdo al 
orden en el que hayan 
ingresado en ía cola de 
salida. 



nado usuario. Su presencia es necesaria 
habida cuenta que el MP/M soporta hasta 
16 consolas y este número es necesario 
en la formulación de ciertos comandos. 

ATTACH 

Este comando tiene encomendada la mi- 
sión de devolver a la consola el control de 
un programa o proceso, después de que 
este haya sido desligado de la misma por 
efecto del comando CONTROL-D. Per- 
mite seleccionar cuál de los programas 
activos en un momento determinado 
debe quedar de nuevo bajo control. A la 
luz de lo comentado, se observa que AT- 
TACH es un comando más selectivo que 
CONTROL-D en su faceta de devolución 
de control. Su formato es: 

A> ATTACH Nombre del programa 
ABORT 

Fuerza el abandono de la ejecución de un 
programa antes de que éste concluya por 
sí mismo. En el caso de que el programa 
haya sido llamado desde una consola dife- 
rente, habrá que incluir en el formato de la 
orden el número de Ja consola o terminal 
en cuestión. Hay que tener en cuenta que 
la ejecución del programa puede haberse 
activado desde otro terminal del sistema. 
El formato de la orden es: 

A>ABORT n Nombre del programa 

El número "n" es opcional, refleja el nú- 
mero de consola desde la que fue llamado 
el programa. 

SPOOL 

La función de este comando es permitir el 
uso concurrente, por parte de varios usua- 
rios, de una única impresora. Para ello, el 
ordenador envía la información de salida a 
un fichero en disco y crea unas colas para 
salida a través de impresora a medida que 
van llegando nuevos ficheros para impri- 
mir. La referida información de salida es 
canalizada hacia la impresora de forma se- 
cuencia!, en el mismo orden en el que fue 
incorporándose a la cola de impresión. El 
formato del comando SPOOL es el si- 
guiente: 

A>SPOOL Nombre de fichero Salida 

La orden admite la expresión de varios 
ficheros de salida; fa única limitación en 
este punto fa impone la longitud de la 
línea de órdenes. 
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Visicalc (1) 

Las facultades de una hoja 
electrónica versátil y popular 




I paquete de aplicación VlSf- 
CALC es, sin lugar a dudas, 
uno de los más populares y 
presentes en el mercado del 
software de aplicación. Su autoría se debe 
a la firma americana Visi Corp. 
El éxito del paquete VISICALC se debe, 
entre otros condicionantes, a que fue la 
primera hoja electrónica que llegó al mer- 
cado. Otro factor también importante es- 
triba en la profusión de versiones que 
existen, lo que permite su empleo en un 
gran número de ordenadores personales, 
desde los distintos modelos de Apple, 
hasta el doméstico Atan, pasando por el 
ÍBM-PC y todos sus compatibles. 

PRESENTACION DEL VISICALC 



Inicialmente, la hoja electrónica VISICALC 
se diseñó para la resolución de problemas 
financieros y de gestión por medio de or- 
denadores personales. Se intentaba lo- 
grar, de esta forma, que los usuarios fina- 
les pudieran utilizar el ordenador para re- 
solver sus problemas concretos, sin nece- 
sidad de desarrollar programas específi- 
cos para cada uno de ellos. 
La evolución de esta hoja electrónica ha 
sido constante, hasta el punto de que en 
ia actualidad existen versiones de distin- 
ta potencia, entre las que cabe destacar 
como más modernas el Adv. VISICALC y 
el VISICALC IV. Ello permite al usuario 
elegir entre ellas la variante más apropiada 
a sus necesidades y capacidad econó- 
mica. Además de poder decidir entre las 
versiones existentes dentro de la línea ofi- 
cial del producto, existen muchas otras 
empresas de software que han desarro- 




TECLAS DE USO FRECUENTE 



MOVIMIENTO DEL 
CURSOR: ARRIBA 

MOVIMIENTO DEL 

CURSOR ae~.: 

MOVIMIENTO DEL 
CURSOR: DERECHA 

MOVIMIENTO DEL 
CURSOR; IZQUIERDA 



MOVIMIENTO RAPIDO DEL 
CURSOR, SEGUN COORD. 

EJECUCION 
DEL COMANDO 

EJECUCION 
DE FUNCION 



Para utilizar con 
eficacia las 
posibilidades del 
VISICALC es 
preciso que el 
usuario se 
familiarice con el 
teclado de su 
ordenador. Las 
teclas que 
aparecen en la 
figura son las de 
uso más 
frecuente. 



RETURN 



FINALIZACION DE 
ENTRADA DE DATOS 



Hado productos auxiliares o complementa- 
rios. 

Al principio se ha señalado que el VISI- 
CALC está disponible para varios ordena- 
dores personales, de distintos fabrican- 
tes. En consecuencia, es obvio que exis- 
ten dialectos preparados para trabajar bajo 
distintos sistemas operativos como, por 
ejemplo, el CP/M, MS/DOS, Apple DOS 
y, en general, cualquiera de los sistemas 
operativos más extendidos. 



CARACTERISTICAS TECNICAS 
DEL VISICALC 



La aplicación utiliza la pantalla del ordena- 
dor personal como ventana de una matriz/ 
hoja, en la que el usuario puede realizar 



BORRADO 



FORMATO 



GESTION 



J_ 



ÍB ELEMENTO 
!/C HOJA 
ID LINEA 



LINEA 
GLOBAL 



/R 


REPITE 


m 


MUEVE 


l : 


INSERTA 




comandes 

4 
e 

i 

VISICALC 




VENTANA 



ALMACENAMIENTO 




/T 



/W 



/S 



/P 



Selección de 
comandos de la 
aplicación de 
hoja electrónica 
VISICALC, 
clasificados en 
siete grupos de 
acuerdo a su 
utilidad. Tai 
corno se observa, 
Iodos ellos van 
precedidos por el 
indicador de 
comando 7 \ 



197 



Aplicaciones 



sus "anotaciones". El tamaño físico de la 
matriz se eleva a un máximo de 254 filas y 
63 columnas. 

Las filas se numeran, como es tradicional, 
mediante números consecutivos 1, 2, 3, 
252, 253, 254; sin embargo, las colum- 
bas se identificarán mediante letras A B, 
C, Bf, BJ, BK. 

Las "medidas" de la hoja son lo suficien- 
temente grandes como para que el ta- 
maño de la pantalla no permita represen- 
tar toda la información de la hoja compieta 
de una sola vez. De ahí que la pantalla se 
utilice a modo de ventana; ventana que 
puede desplazarse sobre la hoja electró- 
nica para examinar y/o modificar la zona 
adecuada. Se puede realizar un SCROLL 
de la ventana o pantalla a través de la hoja 
total si bien, cuando lo que se desea es 
desplazarse rápidamente a través de la 
misma, resulta mucho más apropiado uti- 
lizar el comando de salto (/>}. Este último 
permite ir directamente a la casilla cuya 
letra de columna y número de fíla se es- 
pecifican. 

Además de las teclas especiales del ter- 
minal en el que se esté trabajando, exis- 
ten dos tipos de operadores aportados 
por el VISICALC: funciones y comandos. 
Las funciones se pueden utilizar para las 
fórmulas de cálculo, con las que se defini- 
rán los elementos variables de Ja matriz, 
mientras que los comandos resultan ade- 
cuados para gestionar la hoja electrónica. 
Para poder utilizar eficazmente el VISI- 
CALC, es imprescindible que el usuario 
conozca el teclado de su ordenador. Este 
será el intermediario entre sus deseos y la 
hoja. Las teclas que se utilizarán con ma- 
yor frecuencia son las que aparecen en la 
tabla adjunta. 

Además de estas teclas especiales, en 
una sesión de trabajo con VISICALC será 
necesario utilizar las tecias alfabéticas 
para introducir los literales y las teclas nu- 
méricas para introducir los datos. 
Para completar el análisis de las caracte- 
rísticas técnicas del VISICALC, a continua- 
ción se detallan los comandos y funciones 
más relevantes que incorpora. 

COMANDOS DEL VISICALC 



can por medio de una letra precedida por 
ei símbolo V\ De esta forma, el pro- 
grama sabrá diferenciar entre una letra re- 
presentativa de un comando y una letra 
que identifica a una columna de la hoja 
electrónica. Para ejecutar un comando 
basta, pues, con pulsar la tecla V e intro- 
ducir a continuación la tecla alfabética co- 
rrespondiente. Los principales comandos 
del VISICALC son los que se relacionan en 
los siguientes apartados. 

1. BORRADO DE UN ELEMENTO 
* 

Se identifica mediante la letra B y sirve 
para eiiminar el contenido del elemento 
en que se encuentra ei cursor Suele utili- 
zarse para corregir errores. 

2. BORRADO DE UNA PAGINA 

El comando adecuado se identifica por 
medio de la letra C. Su acción borra com- 



usuario debe responder accionando la te- 
cla "Y" (YES). 

3, BORRADO DE UNA LÍNEA 

Corresponde a la letra D, La ejecución de 
este comando borra completamente el 
contenido de una fila o columna. Cuando 
el usuario lo invoca, yantes de producirse 
el efecto deseado, el VISICALC pregunta 
si la línea que se desea borrar es una fila o 
una columna. Acto seguido, según la res- 
puesta del usuario, se eliminará la infor- 
mación contenida en la fila o columna en 
la que se encuentre situado el cursor. 

4. FORMATEO DE UN ELEMENTO 

Es activado por la letra F, Permite al usua- 
rio definir el modo en el que desea repre- 
sentar el contenido de un elemento. Se- 
gún la letra pulsada a continuación de 
'7F'\ quedará seleccionado un formato 




La aplicación ofrece tres comandos básicos para el horrado: de elementos, de líneas (fila o 
columna, según se especifique) o de la hoja completa. Su actuación queda reflejada en la 
figura adjunta. 



Todos los comandos que el VISICALC 
pone a disposición del usuario se identifi- 



pletamente el contenido de la hoja elec- 
trónica. Su empleo sólo es conveniente 
cuando ha concluido el trabajo en curso y 
se desea comenzar otro. 
El campo de actuación de este comando 
se limita a la memoria principal del orde- 
nador y, por lo tanto, no afecta a los datos 
que pudieran estar almacenados en disco. 
No cabe duda que su uso puede resultar 
peligroso, ya que si se introduce por error, 
puede dar lugar al borrado de una hoja que 
interesa conservar. Para evitar este tipo 
de accidentes, el programa solicita la con- 
firmación del comando, para lo que el 




Los comandos de formato permiten definir 
las características de representación de los 
distintos datos en las casillas o elementos de 
la hoja electrónica. 
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Insertar, mover y repetir o duplicar datos en 
distintos elementos, son operaciones básicas 
para el trabajo con ía hoja electrónica. Las 
herramientas adecuadas ai efecto cabe 
encontrarías en el apartado de comandos de 
gestión del VISICALC. 



específico; Jas posibilidades son las si- 
guientes: 

D: Formato en coma flotante, esto es: 
representación de un número con 
tantos decimafes como sea preciso. 

I : Formato entero y, por lo tanto, repre- 
sentación del número sin decimales. 

L: Formato ajustado al margen iz- 
quierdo del elemento o cas i I ta. 

R: Formato ajustado al margen derecho 
del elemento. 

$: Formato con dos decimales, 

*: Formato para reemplazar el conte- 
nido del elemento portantes asteris- 
cos como su valor entero (útif para 
realizar gráficos). 

5. FOR MATEO DE UNA PAGINA 

El comando al efecto se identifica me- 
diante la letra G y sirve para especificar 
características de la hoja en la que se de- 
sea trabajar. Este comando se activa pul- 
sando "/G" y una segunda letra que de- 
fine la opción elegida: 
C: Define el ancho de una columna con 

un mínimo de tres caracteres. 
F: Define el formato de todos los ele- 
mentos de una hoja, (igual que el 
comando F, pero aplicado a todos los 
elementos y no a ía celda específica 
en la que se encuentra el cursor). 
O: Permite especificar que el recálculo 
de elementos se realice por filas o 
por columnas según desee el usua- 
rio. 

H: Define la prioridad de recálculo; ésta 
puede ser automática o manual. 

6 INSERCION 

La utilidad del comando de inserción, re- 
presentado por la letra I, es la de introducir 
una nueva fila entre dos ya existentes, o 
una nueva columna también entre dos co- 
lumnas ya existentes en la hoja electró- 
nica. Debe acompañarse de una segunda 
letra que puede ser; 

R: Insertar una fila bajo la que contiene 
al cursor. 

C: Insertar una columna tras la que con- 
tiene al cursor. 



COMANDOS DE GESTION 



( inserta ) 
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Elección de una hoja electrónica 



La competencia dentro del mercado , 
actual de hojas electrónicas, entre los 
distintos productos existentes, es tan 
grande que resulta enormemente 
complicado tomar una decisión de 
compra. Tras el éxito inicial de la 
aplicación VISICALC, la práctica totalidad 
de empresas de software se dedicaron a 
producir nuevos paquetes con mejoras 
respecto a su competencia. 
La lucha por alcanzar el primer puesto 
dentro de la lista de productos más 
vendidos, ha acelerado el desarrollo de las 
aplicaciones horizontales de gestión y 
productividad hasta llegar a los modernos 
paquetes integrados. En éstos, la hoja 
electrónica se ve rodeada de otras 
aplicaciones complementarias que abren 
la posibilidad de producir gráficos, aportan 
facilidades de gestión y de edición... 
Tan vertiginoso desarrollo siembra la 
incertidumbre en el usuario a la hora de 
decidir la compra de un determinado 
paquete de aplicación. Desde luego, la 
única forma de garantizar que el producto 
adquirido es el mejor, consiste en esperar 
unos años, y ver cuál de los programas 
termina ganando esta desenfrenada 
carrera. No obstante, esta fórmula resulta 
in viable en la mayoría de los casos. El 
usuario tiene que optar por una alternativa 
y ¡debe decidirlo yaf A continuación, se 
relacionan algunos criterios básicos que 
pueden ayudar a tomar la decisión final; 

t Compatibilidad con el equipo 
informático. 

Si el usuario ya dispone de un ordenador 



personal, la primera criba la realizará 
atendiendo al subcon junto de hojas 
electrónicas que puedan funcionar en su 
equipo. Desde luego, si se molesta en 
analizar la oferta, encontrará varias 
aplicaciones de este tipo compatibles con 
su ordenador. 

2. Fiabitidad del suministrador. 

Otro punto importante a considerar es la 
reputación del vendedor del producto. En 
muchos casos es recomendable consultar 
con el suministrador del equipo que deba 
soportar la aplicación. 

3. Facilidad de aprendizaje. 

Para que el rendimiento de la aplicación 
sea óptimo, hay que evaluar la sencillez 
de su uso práctico y ía disponibilidad de 
manuales o/V otros materiales didácticos. 

4. Características técnicas del producto. 

A los criterios relacionados hasta ahora, 
hay que añadir otro factor de total 
importancia: las propias características 
técnicas de la hoja electrónica. Entre ellas 
cabe destacar los siguientes puntos: 

• Entrada de datos. 

• Comandos disponibles. 

• Tamaño de la "Hoja" (filas y columnas}. 

• Gestión de datos. 

• Capacidad gráfica. 

• Comodidad de uso. 

Todos éstos son apartados cuyo análisis 
específico, para los principales productos 
del mercado, se realizará a lo largo 
de la obra. 
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H comando fW permite utilizar ¡a pantalla a 
modo de ventana, capaz de desplazarse y 
visualizar los distintos fragmentos de la hoja 
electrónica almacenada en la memoria 
central del ordenador. 



7. MOVIMIENTO 

La letra M se encarga de dar entrada a 
este nuevo comando. Se utiliza para mo- 
ver la línea en la que se encuentra el cur- 
sor a una nueva posición, Para ello es 



imprescindible conocer, por un lado, si se 
desea mover una fila o una columna, y por 
otro lado Jas coordenadas del nuevo des- 
tino (el nuevo destino también se puede 
indicar llevando el cursor al mismo, si así 
se desea), 

& REPETICION 

Este comando, representado por la letra 
R, permite repetir el elemento o la línea 
en que se encuentra el cursor, en otra 
posición dentro de la hoja electrónica. En 
el caso de que el elemento repetido sea 
una fórmula, el VISiCALC preguntará af 
operador si desea modificar los paráme- 
tros en la referida fórmula en la nueva 
situación. 

9. TITULOS 

La letra Ida paso a un nuevo comando del 
VISICALC cuyo objeto es reservar posicio- 
nes de la hoja cuyo único destino será 
almacenar títulos. Su puesta en práctica 



evitará errores: si una vez hecha la re- 
serva se pretende introducir un dato o una 
fórmula, con un nuevo comando o directa- 
mente, en alguna de dichas posiciones, ef 
VISICALC avisará def error Dado que los 
títuios pueden colocarse en disposición 



vertical y horizontal, el comando exige una 
segunda letra que indique el sentido del 
título. Las letras destinadas al efecto son: 
H; Título horizontal. 
V: Título vertical. 

10. DEFINICION DE VENTANAS 

Este comando, identificado mediante la 
letra W, permite definir las ventanas den- 
tro de la hoja, para ajustar la zona visible al 
tamaño de la pantalla. 
Existen cuatro posibilidades para la defini- 
ción de ventanas cuya selección corre a 
cargo de las siguientes letras: 

H: Ventanas horizontales. 

V: Ventanas verticales. 

S: Ventanas con paso sincronizado. 

U: Ventanas con paso desíncronizado. 

11. GESTION DEL 
ALMACENAMIENTO 

El comando al efecto se identifica me- 
díante la letra S y permite traspasar infor- 
mación de la hoja en curso a un soporte 
de almacenamiento externo. Para indicar 
el tipo de operación deseado, hay que 
elegir entre alguna de las siguientes op- 
ciones: 

L: Cargar en memoria, una hoja resi- 
dente en disco. 

S: Grabar en disco la hoja electrónica 
que se encuentra en la memoria cen- 
tral del ordenador. 

D: Borrar un fichero en disco con infor- 
mación de una hoja electrónica. 

íi Inicializar (preparar) un disco desti- 
nado a almacenar hojas electrónicas. 

Q: Terminar la sesión de trabajo con el 
VISICALC sin grabar en disco la infor- 
mación. Dado que con esta opción se 
puede perder información útil, el pro- 
grama pide af usuario que Ja confirme 
medrante la letra "Y" (YES). 

#: Gestionar de forma conjunta varias 
hojas electrónicas, con objeto de in- 
corporar en la hoja actual otra hoja 
electrónica o parte de ella, 

12. IMPRESION 

A través del comando de impresión, letra 
P, es posible definir el tipo de impresora 
conectada al equipo y ordenar la impre- 
sión en papel de una hoja electrónica. 
El próximo capítulo se ocupará del estudio 
de las funciones que puede manejar el 
VISICALC. Ello constituirá la etapa previa a 
una sesión práctica de trabajo con esta 
popular hoja electrónica, 
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Aportando datos 
a la máquina 

Los comandos READ, DATA y RESTORE 



ualquier programa, sea cual 
fuere su naturaleza (de ges- 
tión, educativo o, sencilla- 
mente, lúdico) necesita mani- 
pular una cierta cantidad de datos, que 
deben ser entregados a la máquina para 
que los elabore. Estos pueden incluirse 
dentro del propio programa, o incluso 
puede suministrarlos el usuario, en un de- 
terminado momento, a través del teclado. 

DIFERENCIACION DE LOS DATOS 



En términos generales cabe hablar de dos 
tipos de datos o, más exactamente, de 
dos formas de aportarlos al programa: 
como valores constantes o a modo de 
variables. 

Aún cabe establecer entre los datos otra 
división, quizá no tan clara y definida 
;omo la anterior, pero no por ello menos 
válida. Esta división nace de su propia utili- 
dad: ciertos datos van a mantener valores 
fijos y determinados en las sucesivas eje- 
cuciones del programa; por el contrario, 
otros verán alterado su valor, ya que el 
orograma los modificará para ofrecer al 
usuario el resultado de la ejecución. 
Un ejemplo clarificará este extremo. Si se 
quiere obtener al cabo de un año el total 
de gastos mensuales de una familia, ha- 
brá que utilizar al menos dos variables con 
distinta función. Por un lado, el programa- 
dor debe tener presente que el año 
consta de doce meses y, por lo tanto, 
"abrá que considerar doce entradas de 
datos, una para cada mes del año Por otro 
5do, hay que contar con otra variable que 
'á acumulando las sucesivas cantidades 
mensuales. 

Un programa capaz de realizar estos cal- 
rulos es, por ejemplo, el que sigue: 



POR MEDIO 

DEL 
PROGRAMA 




i NECESITO 
DATOS ! 



I¿= 




A TRAVES 
DEL 
TECLADO 



El cometido genérico del ordenador es 
manipular datos de acuerdo a las 
indicaciones aportadas por el programa. Los 
dalos pueden suministrarse a través de dos 
vías principales: el teclado y formando parte 
del propio programa. 



10 LET SUMA=0 
20 FOR M=1 TO 12 
30 INPUT A 

40 LET SUMA=SUMA+A 
50 NEXT M 
60 PRINT "GASTO ANUAL= 
70 END 




SUMA 



Su ejecución interrogará al usuario acerca 
de los sucesivos gastos mensuales, hasta 
completar la introducción de datos men- 
suales; tras ello, mostrará el valor del 
gasto anuaL 

RUN 

735650 

742500 



715250 

GASTO ANUAL= 



525345 



El programa propuesto comienza por inr- 
cializar a cero la variable SUMA r para acu- 
mular en ella los doce valores, ingresados 
a través del teclado y asignados a la varia- 
ble A Esta forma parte de un bucle que se 
ejecutará doce veces. 
Las dos variables en juego, SUMA y A r 
adoptarán valores muy diferentes en cada 
ejecución del programa: (os gastos de un 
mes serán, por lo general, muy distintos a 
los de otro. Sin embargo, la variable de 
control del bucle FOR/NEXT (M), siempre 
adoptará los valores comprendidos entre 
uno y doce. 

Desde luego que éste es un ejemplo tri- 
vial; en todo caso, existen muchas varia- 
bles dentro de un programa que tienen el 
carácter fijo de la variable M. Por ejemplo: 
los nombres de los meses, el nombre y la 
fecha de nacimiento de los miembros de 
una familia o de los trabajadores de una 
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empresa es resultados de los partidos de 
fútbol de 1 año anterior... A este tipo de 
variables de carácter fijo, se les podría 
asignar, como es lógico, sus valores me- 
z'-:. ":~jcciones INPUT. Valores que 
se _ án a través del teclado cada 

r^e se ejecute el programa. No obs- 
ta—- | dado que estos valores son siem- 
pre Sos mismos, es obvio pensar que se 
i- :**e' a mucho tiempo y molestias, si su 
r : z - = :ión corriera a cargo del propio pro- 
guama. 

Una forma elemental de almacenar ios re- 
feridos datos por medio del programa la 
aporta la instrucción LET, adecuada para 
asignar directamente los valores desea- 
dos a las variables. Así, por ejemplo, se 
podrían almacenar los nombres de los 
días de la semana de la siguiente forma: 



10 LET Dl$= 
20 LET D2$= 
30 LET D3$= 
40 LET D4S= 
50 LET D5$= 
60 LET D6S 
70 LET D7S 



LUNES" 
MARTES" 
MIERCOLES" 
JUEVES" 
"VIERNES" 
"SABADO" 
"DOMINGO" 



Ello hará que el programa los tenga a su 
disposición en cualquier momento, ob- 
viando la necesidad de introducirlos cada 
vez que se desee ejecutarlo. Si el número 
de variables fuese reducido, ésta sería 
una opción viable y bastante eficaz, pero 
¿qué ocurriría si el número de variables de 
este tipo fuese elevado? 

LEYENDO LOS DATOS 



Naturalmente, si hubiera que almacenar, 
por ejemplo, los resultados de los partidos 
de fútbol de la temporada pasada a base 
de instrucciones LET o INPUT, sería una 
tarea larga y tediosa. Afortunadamente, el 
BASIC cuenta con otras instrucciones que 
resuelven este problema con mayor co- 
modidad. 

Las referidas instrucciones son READ y 
DATA. Ambas deben coexistir obligatoria- 
mente dentro de un programa, esto es: sí 
se utiliza una instrucción READ, debe 
existir forzosamente al menos una ins- 



trucción DATA. La razón se comprenderá 
fácilmente una vez que se conozcan las 
funciones que realizan cada una de ellas y 
que, en esencia, se resumen en lo si- 
guiente: las instrucciones DATA contie- 
nen los valores fijos que se desea asignar 
posteriormente a las variables, mientras 
que las instrucciones READ se encargan 
de leer el argumento de la instrucción 
DATA y asignar los valores de su argu- 
mento a las variables especificadas en la 
instrucción READ, 

FORMATOS DE READ Y DATA 



Como toda instrucción BASIC, tanto 
READ como DATA deben ajustarse a un 
formato sintáctico que es preciso respetar 
escrupulosamente. De lo contrario, la ins- 
trucción no será aceptada por el intérprete 
BASIC y la máquina generará un mensaje 
de "error sintáctico", 
El formato de la instrucción READ es el 
siguiente: (Núm. línea) READ <var>], 
<var.>, <var >] 

La palabra clave READ debe ir precedida 
por el siempre obligatorio número de lí- 
nea, propio de las instrucciones formula- 
das en modo indirecto (dentro de un pro- 
grama). Su argumento incluirá a una serie 
de variables, separadas por comas, cuyo 
número es opcional; aunque siempre 
debe estar presente al menos una varia- 
ble Por ejemplo: 

10 READ A 

20 READ A, B, C$ 

A su vez, el formato de una instrucción 
DATA es el que sigue : 

(Núm. línea) DATA <cte,> [, <cte.> 

<cte>] 




DATOS DEL PROGRAMA RESULTADOS 



En términos generales, los datos pueden 
incluirse dentro de los programas adoptando 
la forma de variables o de valores 
constantes. Su tratamiento dará lugar a la 
generación del resultado o resultados del 
proceso. 




Son tres las herramientas fundamentales que 
proporciona el BASIC para suministrar datos 
a la máquina; éstas coinciden con las 
instrucciones INPUT, LET y t on la 
a socia ción READ} DA TA . 



Este formato es muy similar al anterior. 
Ahora, la palabra clave, DATA, irá seguida 
por al menos un dato; éste puede ser una 
constante de tipo numérico o alfanumé- 
rico (cadena de caracteres). Normalmente 
serán varios los datos incluidos en el argu- 
mento y que aparecerán separados por 
comas: 

10 DATA 7,2,5,20,3 
20 DATA LUNES 

Las instrucciones DATA son leídas por las 
instrucciones READ, de acuerdo al orden 
que establecen sus números de línea aun- 
que éstos no sean correlativos. En mu- 
chos dialectos BASIC los datos alfa numé- 
ricos pueden escribirse sin encerrarlos en- 
tre comillas; por supuesto, excepto en el 
caso de que el literal contenga alguna 
coma (, ), con objeto de que la máquina no 
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La actividad del ordenador supone la manipulación de datos, la ejecución de cálculos y, en 
definitiva , el tratamiento de los mismos de acuerdo a la secuencia de ordenes denominada 
programa. 



la confunda con las comas utilizadas para 
separar a los distintos datos. Esta obser- 
vación es extensiva a las cadenas de ca- 
racteres que incluyan el signo dos puntos 
(:}, para no confundirlo con el separador 
de dos instrucciones en la misma línea, o 
espacios en blanco significativos detrás o 
delante de la constante. Por ejemplo: 



DATA MARTIN, 
DATA "HORA:" 



"SANCHEZ/' 
"MINUTOS 



.ENRIQUE 



Las instrucciones DATA incluirán valores 
de tipo numérico o literal. No se admiten 
expresiones numéricas, ya sea con opera- 
ciones matemáticas o lógicas entre los 
datos. 



Así r por ejemplo, no serán aceptadas las 
siguientes instrucciones: 

10 DATA 3/4 

20 DATA A AND B,C0RB 

En ambos ejemplos, los valores aportados 
en las sentencias DATA podrían ser leídos 
como cadenas de caracteres, pero no re- 
sultarán válidos si su misión es aportar el 
valor resultante de las expresiones arit- 
méticas o lógicas. 



READ-DATA: 

UNA PAREJA INDISOLUBLE 



Una vez presentado el formato de ambas 
instrucciones, cabe analizar su funciona- 
miento y la forma de utilizarlas dentro de 
un programa, 

Tal como se mencionó anteriormente, si 
en un programa se utiliza una instrucción 
RÉAD para la lectura de datos, debe estar 
presente en el mismo programa al menos 
una instrucción DATA. Ello resulta impres- 
cindible para que READ pueda leer valores 
y asignarlos a las variables especificadas 
en su argumento. 

La instrucción READ asignará los valores 
que lea en la sentencia DATA de la si- 
guiente forma: a la primera variable conte- 
nida en READ le asignará el valor de Ja 
primera constante que aparezca en la pri- 
mera instrucción DATA (atendiendo al or- 
den de numeración de las líneas); a la 
segunda variable, le asignará el segundo 
valor constante que lea en el correspon- 
diente DATA, y así sucesivamente hasta 
que quede con asignación la última varia- 
ble incluida en la instrucción READ. 
Veamos un ejemplo: 




Lee datos de una instrucción DATA y los asigna a las variables especificadas en su 
argumento. 

Formato: {MI) READ <var.> [, <var.>, ... r <var >] 

Ejemplos: 10 READ A 

20 READ A, B, C 

40 READ ZS, DOT$, A 




READ 
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W READ A,B,C 
20 PRINT A^B+C 
30 DATA 1530,10 
40 END 



En este caso, la instrucción READ asig- 
naré a la variable A el valor 15 r a la variable 
B el vafor 30 y a la variable C el valor 1 0 
_-- ejecución del programa mostrará en la 
pantalla el siguiente resultado: 



RUN 

55 



Los valores a asignar a las variables que 
acompañan a READ no tienen por qué 
estar contenidos en una única instrucción 
DATA, sino que pueden estar distribuidos 
en varias. La instrucción READ leerá los 
valores de la primera DATA hasta que 
agote sus datos; a continuación, empe- 
zará a leer de la siguiente instrucción 
DATA, prosiguiendo con una tercera sen- 
tencia DATA si fuera necesario, hasta 
completar la asignación. Así, el programa 
que sigue conduce al mismo resultado 
que el propuesto en el ejemplo anterior: 



10 READ A,B ( C 
20 PRINT A+B+C 
30 OATA 15 
40 OATA 30 
50 DATA 10 
60 END 




Las instrucciones DATA 
almacenan los ¿latos que 
serán leídos por el 
ordenador al ejecutar las 
corte sp ondien res 
in s trt i re -lo/ íes REA D . 



de las sentencias DATA, En consecuen- 
cia, una tercera alternativa para el mismo 
ejemplo será: 



10 READ A 
20 READ B 
30 READ C 
40 PRINT A+B+C 
50 DATA 15 
60 DATA 30 
70 DATA 10 
80 END 



Si el número de variables a asignar con 
READ, o el número de constantes que hay 
que aportar, son considerables, será pre- 
ciso utilizar varias sentencias READ y va- 
rias sentencias DATA para cumplimentar 
fas asignaciones. 

Las instrucciones READ y DATA pueden 




estar distribuidas en cualquier zona del 
programa: si bien, hay que respetar el or- 
den en el que deben ser leídas. Una cos- 
tumbre generalizada es agrupar a todas 
las instrucciones DATA para dar mayor 
claridad al listado del programa, aunque 
ello no debe considerarse como una regla 
inquebrantable. 

La naturaleza de las variables (numéricas 
o de cadena de caracteres) a las que se 
asignará un valor por medio de READ r 
debe coincidir con la naturaleza (numérica 
o alfanumérica) de las respectivas cons- 
tantes incluidas en la correspondiente ins- 
trucción DATA. De lo contrario, se produ- 
cirá un mensaje de "error de asignación" 
( /P type mismatch error", o algo similar), ya 
que no es admisible el intento de asignar 
una cadena de caracteres a una variable 
numérica o viceversa. 



10 READ A, NS 
20 DATA PEPE,35 
30 PRINT N$;"t¡Gne" 
40 END 



A," discos 



La ejecución de las líneas anteriores, pro- 
ducirá en la pantalla el mensaje de error 
señalado. Para solventarlo, habrá que mo- 
dificar la línea 10 como sigue: 
10 DATA 35, PE PE 

Ahora, la ejecución se realizará sin pro- 
blema alguno: 



RUN 

PEPE tiene 35 discos 





Una de las ventajas de las instrucciones 
DATA radica en que para alterar los va lo- 




Almacena datos numéricos o cadenas dé caracteres para su lectura por medio de instruc- 
ciones READ. 



Formato: (NI) DATA <const> [, <const. 



<const>] 



Algo análogo ocurre con las instrucciones 
READ, ya que su formato es semejante al 



Ejemplos: 10 DATA 1,5,7,30.3,0 

SO DATA "SOFT:", I50, PTAS 
85 DATA LUNES, 20, ABRIL 
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Evolución de las unidades 
de almacenamiento externo 



Las memorias de masa o auxiliares son 
dispositivos periféricos destinados a 
almacenar de forma permanente grandes 
volúmenes de información, ya sean 
programas o datos. 

Un programa almacenado en una unidad 
de este tipo no es directamente 
ejecutable, sino que, para que ello sea 
posible, es preciso trasladarlo 
previamente a la memoria central del 
ordenador. 

Esta categoría de dispositivos presenta 
una característica fundamental: la 
información almacenada no es volátil, o lo 
que es lo mismo, no se borra al 
desconectar la alimentación. Ello permite 
conservar los programas y datos para 
emplearlos en cualquier otra ocasión. Su 
actuación se fundamenta en el 
aprovechamiento de las propiedades 
magnéticas, o en ef control de la variación 
de la estructura física, de determinados 
materiales que constituirán el soporte de 
almacenamiento. 
Probablemente, el primer soporte 
empleado para almacenar datos y 
programas en un ordenador fue la tarjeta 
perforada. Estas empezaron a utilizarse en 
la industria textil tras su invención por 
Joseph Jacquad. Más tarde, las tarjetas 
perforadas fueron empleadas por 
Hermann Hollerith en una máquina 
destinada a procesar la información 
referente a ! cení o de los Estados Unidos. 
Una tarjeta perforada consiste en una 
simple cartulina rectangular en la que se 
disponen 12 filas con 30 columnas, cada 
una de posibles perforaciones. La 
presencia o ausencia de perforación en 



los diversos puntos es, precisamente, lo 
que permite representar distintas 
informaciones. Para trasladar la 
información a la tarjeta se emplea 
comúnmente un código especial, llamado 
código Hollerith; éste permite codificar 
cualquier carácter en una columna de la 
tarjeta. 

La perforación de las tarjetas se realiza 
medíante unas máquinas especiales 
llamadas perforadoras de tarjetas. Su 
lectura puede llevarse a cabo por 
procedimientos mecánicos (escobillas) u 
ópticos (células fotoeléctricas). En la 
actualidad, este soporte ha quedado 
totalmente obsoleto y su presencia se 
reduce a instalaciones anticuadas de 
grandes ordenadores. 
Las cintas de papel perforado constituyen 
otro de los soportes de almacenamiento 
en desuso en nuestros días. Son simples 
cintas de papel, en las que se practican 
las perforaciones adecuadas para codificar 
la información. Hoy en día están 
presentes en algunos teletipos. 
Las propiedades magnéticas de 
determinados materiales empezaron a 
aprovecharse para construir los primeros 
soportes de memoria en cinta magnética. 
En esencia, la constitución y 
funcionamiento de las unidades 
apropiadas no difiere de la de los 
magnetófonos a cásete convencionales. 
Tampoco ei soporte difiere en exceso. Se 
trata de una cinta plástica sobre la que se 
deposita una capa de material 
magnetizable. Esta, que constituye la 
superficie exterior de la cinta, es la que 
memoriza la información en forma de 



dominios magnéticos en d¡stmta 
orientación. Su tamaño, longitud, formato 
y capacidad varían según el modelo. 
Las cintas magnéticas son soportes de 
tipo secuencial. Ello supone un 
inconveniente, puesto que para acceder a 
una información específica es necesario 
pasar por todas tas informaciones que la 
preceden, con la consiguiente pérdida en 
tiempo de acceso. Semejante problema 
no es exclusivo de las cintas magnéticas, 
sino que afecta también a las tarjetas 
perforadas y a la cinta de papel. 
Otro método, también basado en las 
propiedades magnéticas de algunos 
materiales, es el de los tambores 
magnéticos. Consisten en unos cilindros 
sobre los que se deposita una capa de 
material magnetizable capaz de retener la 
información. Esta se graba y se lee 
mediante un cabezal cuyo brazo se 
mueve en la dirección del eje de giro del 
tambor; realizando los giros adecuados 
del tambor, será posible actuar libremente 
sobre cualquier punto de la superficie del 
cilindro. Por consiguiente, el acceso a la 
información es directo y no secuencia!. 
En la actualidad, el sistema más 
extendido lo constituyen los discos 
magnéticos, ya sean de tipo flexible 
l.floppy disc) o rígidos, además de ciertas 
variantes menos extendidas. En esencia, 
se trata de un disco de plástico sobre ei 
que se realiza la consabida operación de 
depositar una capa de material magnético. 
Estos discos presentan la ventaja de 
permitir un acceso directo o aleatorio a 
cualquier punto de su superficie, ventaja 
que comparten con el tambor magnético. 
Hoy en día se sigue investigando con 
empeño en este campo, y no sólo para 
desarrollar nuevos periféricos de 
almacenamiento — ahí están, por ejemplo, 
las unidades de disco óptico a láser — r 
sino también para mejorar la capacidad y 
eficacia de los dtscos y cintas magnéticas. 
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res de los datos del programa, sólo hay 
que modificar esas líneas; no hay necesi- 
dad de cambiar cualquier otra instrucción 
operativa, 

Cuando ef número de constantes inclui- 
das en una sentencia DATA no es fijo, 
sino que en una futura ejecución del pro- 
grama puede verse ampliado con nuevos 
datos, es posible recurrir a un sencillo 
truco. Consiste en introducir un dato es- 
pecial (distinto de cualquiera de los valo- 
res que lo preceden) a] final de las cons- 
tantes de la última sentencia DATA. Este 
servirá como indicador de que ya se han 
leído todos los datos anteriores. De esta 
forma, será posible modificar el número 
de constantes a Jeer sin alterar por ello el 
programa principal. El siguiente ejemplo 
ilustra la técnica enunciada: 

10 LET S=0 

20 FGROÜTÜ 1STEP0 
30 READ D 

40 IF D = -l THENLETC=1 

50 IF D< >-1 THEN LETS=S+D 

60 NEXT C 

70 PRINT "SUMA="; 3 
80 DATA 10,2,8,23,5,-1 
90 END 

Su ejecución se traducirá en ef contenido 
de la siguiente pantalla: 



RUN 

SUMA=48 



La instrucción READ irá leyendo los datos 
de la sentencia DATA, uno por uno, y acu- 
mulándolos en la variable S, hasta que 
llegue al valor —1, el último. Su lectura 
hará que la variable C que controla al bucle 
tome el valor -1 , con lo que se abandonará 
el bucle FOR/NEXT y se imprimirá en la 
pantalla el resultado de la suma de los 
números aportados en la línea 80. 
Si se desea modificar los datos a sumar, o 
simplemente añadir más números a la 
lista, será suficiente con alterar la línea 80 r 
sin tocar para nada el resto del programa. 



READ. 



DATA [ 



El funcionamiento del par READ ¡DATA es 
indisoluble. Cualquier instrucción READ, 
exige la presencia de una instrucción DA TA 
que aporte los valores a asignar. Estos serán 
asignados a las variables incluidas en el 
argumento de la instrucción READ, 

PROGRAMA 



DATA 



o 
o 
o 
o 
o 
o 
o 



RESTORE 



READ 



La instrucción RESTORE permite que el 
argumento de una misma instrucción DATA 
sea leído y, en consecuencia, utilizado por 
su cesiv a s in s tru ce io n es REA D . 



Asi, por ejemplo, si se introduce la línea: 
80 DATA 10,2,8,23,5,6,4,10,-1 
en el fugar de la línea 80 original, la nueva 
ejecución del programa, obtendrá el si- 
guiente resultado: 



RUN 

SUMA=68 



El comando READ se puede introducir 
también de forma directa. No ocurre asi 
con el DATA que, generalmente, debe ser 
ejecutado de forma indirecta, dentro de 
un programa. 

10 FOR 1=1 TO 4 
20 READ D 
30 PRINT D, 
40 NEXT I 
50 DATA 5,7,9,2,10 
60 END 

RUN 

5 7 9 2 



Si se introduce ahora la orden READ D y, 
acto seguido, se ejecuta la instrucción 
PRINT D, aparecerá en la pantalla el nú- 
mero 1 0. Sin embargo, al ejecutar una vez 
más la orden READ D, aparecerá en la 
pantalla un mensaje: "OUT OF DATA 
ERROR" (error de falta de datos). 
Ello se debe a que el ordenador contabi- 
liza interiormente el número de constan- 
tes DATA ya utilizadas, y al terminar éstas 
se ve en la imposibilidad de continuar la 
lectura. 



¿COMO RE UTILIZAR LOS VALORES 
DEL DATA? 



¿Qué hay que hacer si se quieren utilizar 
otra vez, dentro del mismo programa, los 
datos ya leídos por medio de otras instruc- 
ciones READ? El BASIC ofrece como so- 
lución el comando RESTORE. Su misión 
es inicial izar la lista de constantes almace- 
nadas en sentencias DATA al primer valor 
de la primera sentencia DATA, con lo que 
quedan disponibles de nuevo todas las 
constantes DATA. 

El comando RE STORE se puede introdu- 
cir tanto de forma directa como indirecta. 
Cada vez que se utiliza un dato almace- 
nado en una sentencia DATA, se incre- 
menta un determinado registro interno de 
la máquina. Este registro no es más que 
un puntero o indicador que señala a la 
primera constante DATA que aún no ha 
sido utilizada por el programa, Al ejecutar 
la orden RESTORE, se borra el mencio- 
nado registro, con lo que apuntará al prí- 



206 



Basic 



TABLA DE CONVERSION 



ORDENADOR 


READ 


DATA 


RESTORE 


READ <var> 


READ <var.> <var> 


DATA <const> 


DATA <cortst> í ... 1 <const.> 


RESTORE 


RESTORE <nl> 


RESTORE <exp.> 


APPLE II 
(APPLESOFT) 


READ <var> 


READ <var.> <var.> 


DATA < const > 


DATA <const>,... r <const> 


RESTORE 


? 


7 


APRICOT 
(M-BASICJ 




ntnU *--Val , s^j.Tf *<■ Va\ .— ' 


\Jf\ 1 M LUI lo L. 


umia ^ cu ns i..> con si. 


neo F Unt 


rita i unt <-.nir> 


rito l Unt <i sxp. -- 


ATARI 


REA H Uar *s 






DATA < cconst.>,... r <const-> 


ntb 1 Unt 


ntblUnt: <ni> 


nto 1 Unt <exp. .> 


CBM 64 


1 \ LrtU S.¥glj^ 


ncHU Va 1 , ^- vaí .-^ 


UjH 1 M LUI lh |¿ 




uto \ unt 






DRAGON 


READ <\tar > 


RFAD <^Uflr <r\jnr ~> 


■Urt 1 M ^ LUI la L. 


Urtlrt ^-h LU 1 1 i L. .-^ j . . . , LU 1 1 5 1 - 


neo i une 






EQUIPOS MSX 


READ <var.> 


READ <var. >,..., <var> 


DATA <const.> 


DATA <canst> <const> 


RESTORE 


RESTORE <nl > 


RESTORE <exp.> 


HP 150 


READ <var> 


READ <w> r ...,<var.> 


DATA < const > 


DATA < co nst.> ,...,<const> 


RESTORE 


RESTORE <n1 > 


RESTORE <exp,> 


IBM PC 


READ <var> 


READ <var. >,..., <var.> 


DATA <const> 


DATA <const>,..,,<const> 


RESTORE 


RESTORE <n1> 


RESTORE <exp.> 


MPF 


READ <var> 


READ <var > <var.> 


DATA <consL> 


DATA <const>,...,<const> 


RESTORE 




— 


NCR DM V 
(MS-BASIC) 


READ <var,> 


READ <var. >,..., <var.> 


DATA < const > 


DATA <ccnst.>,..,,<const> 


RESTORE 


RESTORE <nl > 


RESTORE <exp.> 


NEW BRAIN 


READ <van> 


READ <van>^.,<var > 


DATA <const> 


DATA < const >,. , < co n st. > 


RESTORE 


RESTORE <nl> 


RESTORE <exp.> 


ORIC 


READ <var> 


READ <var + > <var.> 


DATA <const> 


DATA < const. >,..,< co n st. > 


RESTORE 






SHARP MZ-700 
(MZ-BASÍC) 


READ <vai\> 


READ <var>,...,<var,> 


DATA <const.> 


DATA < const > ,,..,< co n st. > 


RESTORE 


RESTORE <nt > 


RESTORE <exp.> 


SINCLAIR QL 


READ <var> 


READ <var > <var > 


DATA < const > 


DATA < const. > ,. < co n st. > 


RESTORE 


RESTORE <nl > 


RESTORE <exp.> 


SPECTRA VIDEO 


READ <war.> 


READ <var.> <var.> 


DATA <const> 


DATA < const. >,...,< co n st. > 


RESTORÉ 


RESTORE <nt > 


RESTORE <exp.> 


Zx^SPECTRUM 


READ <m.> 


READ <var>,...,<var.> 


DATA <const> 


DATA < const. >,. .. , < co n st. > 


RESTORE 


RESTORE <nl > 


RESTORE <exp > 



<nl>: Número de linea <váf>: Variable, <const >: Constante, <exp >: Expresión numérica con datos y/o variables. 
FORMULACIONES DE LOS COMANDOS 

READ <var.>: Lee un dato de una Instrucción DATA y lo asigna a la variable <var.>. READ <var.> <vac>: Lee tantos datos como variables haya y los asigna a las 

respectivas variables. DATA <const >: Aporta un dato que será leído por medio de jna instrucción READ DATA <const.> <const >: Aporta un conjunto de datos que 

Serón leídos por una o varias instrucciones READ. RESTORE: Inícializa el puntero al primer dato de la primera instrucción DATA del programa. RESTORE <nl>: Imcializa el 
puntero de lectura al primer dato del DATA que ocupa la linea indicada. RESTORE <exr. > n.c¡ai za el puntero al DATA que ocupa la linea cuyo número resulta al evaluar la 
expresión. 

mer dato de la primera sentencia DATA. ten especificar un número de linea [o una 
Algunos dialectos BASIC incluyen una op- expresión que calcula un número de línea 
ción muy útil para este comando: permi- existente en el programa} detrás de la pa- 



restore 






Permite que el argumento de instrucciones DATA sea leído de nuevo por medio de 
instrucciones READ, desde el primer DATA o desde la línea DATA que se especifique. 



Formato: 



RESTORE [<nl>] 



Ejemplos: 10 RESTORE 

80 RESTORE 30 
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10 REM CALENDARIO PERPETUO (19807986) 
20 PR1NT TECHA? (EJ.: 27,11,1984]" 
30 INPÜT D,M,A 

40 ÍF D<1 OR D>31 OR M<1 OR M>12 

THEN GOTO 20 
50 ÍF A<1980 OR A>1986 THEN GOTO 20 
60 RESTORE (200-hA- 1 980) 
70 FOR 1 = 1 TO M 
80 READ NUM 
90 NEXT I 

100 LET NUM -NUM +D 

110 IF NUM>7 THEN LET NUM=|\JUM=7 

120 IF NUM>7 THEN GOTO 110 

130 RESTORE: LET A$=* " 

140 FOR 1 = 1 TO NUM 

150 READ A$ 

160 NEXT I 

170 DATA DOMINGO, LUNES, MARTES 
180 DATA MlERCQLES,JUEVES,VIERNES, 
SABADO 



O 




190 PRINT "EL ";[ 


);" DEL ";M;" DE ";A; rr 


ES ";AS 


200 DATA 2,5,6,2,4 


,0,2,5,1,3,6,1 



201 DATA 4,0,0,3,5,1,3,6,2,4,0,2 

202 DATA 5, 1,1, 4,6,2,4,0,3,5, 1 r 3 

203 DATA 6,2,2,5,0,3,5,1,4,6,2,4 

204 DATA 0,3,4,0,2,5,0,3,6,1,4,6 

205 DATA 2,5,5,1,3,6,1,4,0,2,5,0 

206 DATA 3,6,6,2,4,0,2,5,1,3,6,1 
210 END 




O 

o 

o 



Listado del programo 'Calendario perpetuo" . Una aplicación práctica de la Introducción de 
datos de la mano de instrucciones READ ¡DATA. 




labra clave RESTORE. Con ello, en luga 
de micialízar el puntero a la primera sen- 
tencia DATA, lo hará a la línea DATA indi- 
cada (o a la primera que se encuentre \ 
partir de la especificada) 
Este refinamiento permite empezara leer 
de nuevo Jos datos de cualquier instruc- 
ción DATA, incluso de la última del pro- 
grama, sin más que especificar su número 
de línea. 

El listado adjunto que corresponde a un 
programa de calendario perpetuo consti- 
tuye un compendio de Jos conceptos es- 
tudiados en el presente capítulo. Al intro- 
ducir una fecha determinada a través del 
teclado, el ordenador determinará automá- 
ticamente de qué día de la semana se 
trata. 

La línea 60 ilustra la actuación del co- 
mando RESTORE al inicializarlo a un de- 
terminado número de línea. En este caso 
el puntero de datos se inicializa a la línea 
correspondiente al año introducido, me- 
diante el cálculo de la expresión: 
(200 -i-a- 1980). Su resultado será un nú- 
mero comprendido entre 200 y 206, am- 
bos inclusive. Estos son los números de 
línea de las sentencias DATA que contie- 
nen los valores "mágicos", correspon- 
dientes a cada mes de ese año, que per- 
mitirán hallar ef nombre del día deseado. 
Dicho valor, sumado al día del mes, dará 
un número comprendido entre 1 y 37. A 
través de las líneas 1 10 y 120, el número 
en cuestión se reducirá a un valor com- 
prendido entre 1 y 7 que, como cabe su- 
poner, corresponde af día de la semana 
comenzando por el Domingo. 
Los nombres de los días de la semana 
están memorizados en dos instrucciones 
DATA, localizadas en Jas líneas 170 y 180; 
éstas se inicial izarán con el comando RES- 
TORE de fa línea 130. A partir de ahí, ya no 
queda más que leer el nombre del día con 
una sentencia READ y almacenarlo en la 
variable A$ para su posterior presentación 
en la pantalla: 



RUN 

FECHA/ (EJ.:27,1 1,1984) 
76,2,1985 

EL 6 DEL 1 DE 1985 ES MIERCOLES 



La introducción de datos en eí ordenador a través del programa es una tarea contemplada por 
el lenguaje BASIC, quien dispone de un grupo de comandos especializados en tal cometido. 
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Logo (10) 



Operaciones aritméticas y lógicas 



|| asta ahora sólo se han anal i- 
I zado a fondo las capacidades 
^11 gráficas y de tratamiento de 
| palabras del LOGO. Aunque 
ambos aspectos son primordiales en este 
lenguaje, queda aún por comentar otra 
vertiente fundamental: el tratamiento de 
datos aritméticos y lógicos. El ordenador 
es r básicamente, una máquina capacitada 
para realizar cálculos; en consecuencia, 
todo lenguaje de programación debe in- 
cluir un amplio repertorio de instrucciones 
aritméticas. 

El cálculo numérico no es una posibilidad 
fácil de explotar en el LOGO. Este len- 
guaje, al contrario de otros como el FOR- 
TRAN o el propio BASIC, no está especial- 
mente orientado al cálculo No obstante, 
aporta suficientes funciones aritméticas 
para realizar la mayor parte de las opera- 
ciones habituales, 

PREFIJOS E INFIJOS 



Las órdenes LOGO pueden ser comandos 
u operadores. Las funciones aritméticas 
se encuadran en este segundo grupo. El 
primer operador aritmético a analizar es et 
de suma, materializado por medio de la 
palabra SUM, Como todo operador LOGO 
tiene sus entradas y salidas. Las entradas 
de SUM se colocan a la derecha de la 
orden: SUM 2 3 es un posible ejemplo, Al 
igual que cualquier otro operador, debe 
estar precedido por un comando que "re- 
coja" su dato de salida. 
Dicha forma de realizar la suma y devolver 
el resultado se denomina modo prefijo, 
debido a que el operador precedo a los 
comandos. Este es el método habitual de 




ARITMETICA 



Aunque no está específicamente creado para 
el cálculo matemático y el lenguaje LOGO 
permite programar operaciones aritméticas 
con comodidad. 



utilizar los operadores en LOGO; si bien, 
puede resultar engorroso en el caso de 
ios operadores aritméticos. Esta es la ra- 
zón de que exista otra posibilidad, el 
modo infijo. La nueva modalidad consiste 
en colocar el operador entre los operan- 
dos. En tal caso, hay que sustituir la pala- 
bra SUM por el signo +, por ejempio: 
...2 + 3. Su efecto es idéntico al del ejem- 
plo anterior, aunque su significado es más 
familiar para el usuario. 
Entre los operadores que permiten ambos 
modos de formulación, se encuentran: 
SUM (+) r PRODUCT (*) y EQUALP (=}. 
Junto a los prefijos se indican, entre pa- 
réntesis, los correspondientes infijos. 



PREFIJO 

SUM 


i i 


JUMA 

z 


INFIJO ' ¡ 





Muchos de los operadores matemáticos del 
LOGO pueden adoptar una doble 
formulación: como ' prefijo' 1 (precediendo a 
k > s d a i os í i op e ra r) o " it i fijt .> " (a >h Kai k >s 
entre los datos de entrada h 



Las operaciones básicas del LOGC ■ 
las siguientes: suma [+), resta {-:. 
plicación (*) y división (/). Todas e : :- 
ponen de un operador infijo (entre parer* 
tesis). Sólo el producto (PRODUCT 
suma (SUM) admiten prefijo.- Hay z^ se- 
ñalar que algunos dialectos del LCG~ -- 
cluyen un prefijo para división, core ce "- 
con Ja palabra QUOTJENT. 
Los operadores SUM y PRODUCT 
cen r además, la posibilidad de scepzs* 
más de dos datos de entrada. E''o m 
sigue encerrando el operador y sus dalos 
de entrada entre paréntesis. Pe e : 
(PRODUCT 2 3 4), cuyo da:: i-,::: 
será 24 (2 x 3 x 4). 

Además de las operaciones e e^r";^ 
el LOGO incluye algunas funoones mase- 
máticas complejas. Estas sz" = 
drada (SQRT) y las funciones ' : ; : ~ ~- 
tricas seno y coseno S\ ZZi ~zzzz 
ellas admiten un solo ca:: ze z- 
por lo tanto, deben se j : : - " 
prefijos. Otra función ^: - — . . - 
sos en REMAINDER E^t 
cula el resto ocasionado por a z\sz~ rJe 
los datos colocados a z~z:~ i- Es pe- 
lo tanto, un operacc =~ ^ zzz z^~ ; 
Dentro de ! os c:e'=::'T: 5 — ^' 
pueden considera - ' . . z - z- 

Es dectr r aquellos c ^ r e ^ ■ 
número indicacc : : i .- : - 
ROUND. & p-r-^— ^ez-.z : - _- : 
entera del dato ce 5-*v=*= - _z. 

ROUND zz-.^z-.z- z- : - "e : 

"más cercano" al ciato oe e^-zzz -araeí 
dato 15, 7. IISÍT devuelve eJ vale- 15 
ROUND, por el contrario, ttene zz — z 
sultado el va'or 16. 



Todos estos operadores son utilizados, 
generalmente, para la asignación de valores 
a una variable. He aquí algunos ejemplos. 

MAKE "A 2+3 

MAKE "SUMA SUM ;SUMA : DATO 
MAKE "COSA COS :A 
MAKE "RESUL INT (PRODUCT 2 A SIN :A 
MAKE T0N2+:PE/(5-:A) 

Como puede apreciarse en los ejemplos, 
es posible encadenar operadores. Cuando 
:s operadores encadenados sean infijos, 
se evaluarán primero los productos y divi- 
siones y, más tarde, las sumas y restas. 
En la última línea del ejemplo, se utilizan 
oa rén tesis para que el contenido de la va- 
vaole :PE sea dividido por el resultado de 
5 — :A. Si no se coloca el paréntesis, se 
restaría :Á del cociente de :PE/5. 

NUMEROS ALEATORIOS 




Las comparaciones de datos en LOGO conducen a dos datos de salida de Upo "lógico* 
TR UE í cierro} o FA LSE (falso). 



El lenguaje LOGO dispone también de un 
generador de números aleatorios, muy 
útil en juegos y simulaciones de azar. El 
operador RANDOM, seguido por un nú- 
mero entero, entregaría un resultado alea- 
torio (también número entero) compren- 
dido entre O y el dato de entrada. Por 
ejemplo, RANDOM 5 dará como dato de 
salida un entero menor que 5 



REPEAT 4 fPRINT RANDOM 5) 




. " '- lie terminada secuencia de números 
5 e a tonos puede ser repetida por medio 
de RE RANDOM. La instrucción de este 
comando hace que el ordenador "re- 
cuerde'' la siguiente secuencia aleatoria 
generada; cada vez que se vuelve a ejecu- 
tar el comando RERANDOM, fos números 



aleatorios generados serán repetidos en 
el orden en que fo fueron anteriormente. 
Para la repetición de una secuencia alea- 
toria, es imprescindible que el argumento 
de RANDOM coincida con el propuesto 
en la sentencia recordada. El ejemplo ilus- 
tra esta posibilidad. 

RERANDOM REPEAT 4 (PRINT RANDOM 5) 
1 

3 
4 

2 

RERANDOM REPEAT 4 (PRINT RANDOM 5} 
1 

3 
4 

2 



ARITMETICA Y LISTAS 



* La potencia de! LOGO en el tratamiento 
de listas puede ser aprovechada para fi- 
nes matemáticos. Esta situación nace de 
la posibilidad de tratar listas de números. 
A una lista formada por números pueden 
aplicársele todos los operadores mencio- 
nados en el capítulo de palabras y listas. 
Por ejemplo, FIRST (1 2 3 4) devolverá el 




El operador RANDOM genera un número 
aleatorio, comprendido entre cero y el valor 
especificado coma dato de entrada. 





l os operadores de relación sirven para 
evaluar la certeza { TR UE) o falsedad 
( FALSE) de una comparación de dalos, 



número uno. Este dato de salida puede 
ser posteriormente procesado por opera- 
dores aritméticos. El siguiente procedi- 
miento suma Jos elementos de una lista 
de números. 
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TABLA DE COMANDOS LOGO (1) 


instrucción 


Cometido 


Operador/ 
Comando 


SUM <N1> <N2> 


Realiza la suma de los datos de entrada (prefijo) 


Operador 


<N1> + <N2> 


Realiza la suma de ios datos de entrada (infijo) 


Operador 


PRODUCT <N1xN2> 


Obtiene el producto de los datos de entrada (prefijo} 


Operador 


<N1>*<N2> 


Obtiene el producto de los datos de entrada (infijo) 


Operador 


<fsJ1>-<N2> 


Opera la resta de los datos entre los que se encuen- 
tra (infijo) 


Operador 


<N1>/<N2> 


Divide los datos que acompañan al operador (infijo) 


Operador 


SQRT <N1> 


Hafla la raíz cuadrada del dato de entrada 


Operador 


SIN <N1> 


Calcula el seno del dato de entrada 


Operador 


COS <N1> 


Calcula el coseno del dato de entrada 


Operador 




TABLA DE COMANDOS LOGO (2) 


Instrucción 


Cometido 


Operador/ 
Comando 


RANDOM <N1> 


Genera un número entero aleatorio inferior al valor 
dado 


Operador 


RERANDOM 


Recuerda la última secuencia generada de números 
aleatorios 


Comando 


<N1> > <N2> 


Entrega el dato lógico TRUE si N1 es mayor que N2 


Operador 


<N1> < <N2> 


Proporciona el dato lógico TRUE si NI es menor 
que N2 


Operador 


EQUALP <N1> <N2> 


Proporciona el dato lógico TRUE si N1 y N2 son igua- 
les {prefijo} 


Operador 


<N1> = <N2> 


Proporciona el dato lógico TRUE si N1 y N2 son igua- 
les (infijo) 


Operador 


ÁND <L1> <L2> 


Realiza la función lógica AND (Y) entre los datos de 
entrada 


Operador 


OR <L1> <L2> 


Realiza la función lógica OR (0) entre ios datos de 
entrada 


Operador 


NOT <L1> 


Entrega el valor lógico contrario al dato de entra- 
da (NO) 


Operador 



COMPARACIONES 



El mundo está I ferio de comparaciones, 
derivadas de las diferencias entre los dife- 
rentes individuos. Una persona puede ser 
más alta que otra, o más obesa. En el 
terreno matemático estas comparaciones 
son un calco de las del mundo real. En 
muchos problemas matemáticos resulta 
imprescindible determinar si un número x 
es mayor que otro y. El LOGO aporta tres 
operadores de relación para la compara- 
ción de números: mayor que (>), menor 
que (<) e igual (=), Los tres actúan como 
infijos, aunque ef tercero admite también 
la modalidad prefijo; en tal caso su sinta- 
xis es EQUALP. El dato de salida de estos 
operadores recibe el nombre de dato ló- 
gico, puede adoptar el valor TRUE (verda- 
dero) o FALSE (falso). En esta tesitura, la 
salida de 5 > 6 será FALSE mientras que 
la de EQUALP 5 5 será TRUE. 
Otros operadores de este tipo — con dato 
de salida de tipo lógico — han sido estu- 
diados en capitulares anteriores: LISTP y 
WORDP al hablar de palabras y listas; NA- 
MEP, al hablar de variables: SHOWNP en 
los TURTLE GRAPHICS... 
Los datos de salida de tipo lógico son 
palabras manejables por el LOGO. De he- 
cho, si se precede un operador de este 
tipo por un comando PRINT, en la pantalla 
aparecerá la palabra lógica correspon- 
diente. Por ejemplo: PRINT 5 > 6 escribe 
en la pantalla la palabra FALSE. 
También se pueden utilizar estos datos de 
salida para formar listas, e incluso proce- 
sarlas tal y como se explicó en el capítulo 
dedicado a palabras y listas. Los datos ló- 
gicos tienen además otro significado para 
el intérprete LOGO. Esta segunda caracte- 
rística de las palabras TRUE y FALSE es la 
que se detalla en el siguiente apartado. 



NOTA: <N1> y <N2> representan datos numéricos. 

T0 SUMA: LISTA El significado completo del procedimiento 

IF: EMPTYP: LISTA(0UTPUT 0) [PRINT SUM se comprenderá al tratar la recursivídad en 
FIRST: LISTA SUMA BUTFIRST: LISTA) el capítulo de bucles. Sirva de todas for- 

END mas este ejemplo para ilustrar la posibili- 

dad de operar con listas de números. 



OPERADORES LOGICOS 



Una de fas teorías matemáticas más utili- 
zadas en el mundo de los ordenadores es 
la denominada álgebra de proposiciones o 
álgebra de Boole. Esta parte dG la mate- 
mática moderna se ocupa re las relacio- 
nes entre los enunciados lógicos. En ella 
existen dos operadores lógicos funda- 
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> © = TRUE 



< © = FALS€ J 



Funcionamiento de tos operadores de relación "mayor que*' y ' menor que' 



Tt 



T 



MARTILLOS 0 CLAVOS - TRUE 

MARTILLOS ^ CLAVOS = TRUE 

MARTILLOS (7) CLAVOS - FALSE 

MARTILLOS || CLAVOS = TRUE 

MARTILLOS 0 CLAVOS = FALSE 

MARTILLOS @ CLAVOS = TRUE 

MARTILLOS © CLAVOS = FALSE 

MARTILLOS É| CLAVOS = FALSE 



Y - AND 



-OF 



Salida generada por tos operadores 
lógicos AND (y) y OR (o), ame diversas 
combinaciones de dalos de entrada. 



OPERADORES LOGICOS AND, OR Y NOT 




AND 




OR 




NOT 


DATO 1 DATO 2 


SALIDA 


DATO 1 DATO 2 


SALIDA 


DATO 


SALIDA 


TRUE TRUE 
TRUE FALSE 
FALSE TRUE 
FALSE FALSE 


TRUE 
FALSE 
FALSE 
FALSE 


TRUE TRUE 
TRUE FALSE 
FALSE TRUE 
FALSE FALSE 


TRUE 
TRUE 
TRUE 
FALSE 


T RL E 
FALSE 


FALSE 
TRUE 



mentales AND (y) y OR (oT El cometido de 
ambos salta a la vista al evaluar la dife- 
rencia entre la frase "comeré carne y pa- 
tatas" y la frase "comeré carne o pata- 
tas". 

Al tratar con datos de tipo lógico es 
cuando estos operadores cobran impor- 
tancia. La instrucción AND :B=0 :C=0 
dará el valor TRUE cuando ambas varia- 
bles B y C valgan cero. Realmente, los 
datos de entrada al operador AND son 
datos de tipo lógico; el en caso del ejem- 
plo, coinciden con los datos de salida de 
dos comparaciones. 

Si tanto B como C valen cero, el ejemplo 
anterior equivale a la instrucción AND 
TRUE TRUE, Por el contrario, si C tuviese 
un valor distinto de cero, el equivalente 
sería AND TRUE FALSE 
Estas mismas normas rigen para el uso de 
OR. La diferencia radica en que r mientras 
AND exige que sus dos entradas sean 
TRUE para dar una salida TRUE, a OR le 
basta con que una de ellas sea TRUE. En 
el ejemplo comentado al principio, la pri- 
mera frase será cierta si el individuo 
come ambas cosas, carne y patatas, y 
falsa sí deja de comer alguna de ellas. Por 
el contrario, la segunda frase será cierta 
siempre que corva alguna de las v ancas 
mencionadas y falsa sólo en el caso de 
que no se coma ninguna de ellas. 
Las tablas adjuntas muestran la salida que 
proporciona cada uno de estos operado- 
res para el conjunto de posibles combina- 
ciones de entrada. 

Como quiera que su salida es otro dato 
lógico, resulta evidente que estos opera- 
dores puedan ser encadenados, obte- 
niendo así funciones más complejas. Por 
ejemplo, la posibilidad de comer "sopa y 
carne o pescado, o arroz y carne con pata- 
tas" se formularía de la siguiente forma: 
OR (AMD :SOPA OR : CARNE: PESCADO) 
(AND :ARROZ AND :CARNE: PATATAS). 
La certidumbre de dichos enunciados de- 
penderá del valor lógico de las variables 
:SOPA, : CARNE, etc. 
Existe un tercer operador lógico. Este ac- 
túa sobre un dato lógico, negándolo, esto 
es, inviniendo su valor lógico. El mencio- 
nado operador se denomina NOT (no) y su 
tabla correspondiente es la que aparece 
en la figura. 

Como se puede apreciar en la tabla, el 
operador NOT admite un único dato de 
entrada, entregando el valor lógico con- 
trario. 

Estos tres operadores son suficientes 
para relacionar todo tipo de enunciados. 
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El MP/M en memoria 

Estructura de la memoria del sistema 
operativo MP/M 




esde la perspectiva de cual- 
quiera de los múltiples usua- 
rios conectados a un ordena- 
dor regido por el MP/M, la 
máquina se comporta de forma seme- 
jante a si se tratara de un equipo monou- 
suario dotado del sistema operativo 
CP/M. La única salvedad verdaderamente 
apreciable se encuentra en la disponibili- 
dad de un conjunto de comandos adicio- 
nales; éstos permiten gestionar las trans- 
ferencias de información de una forma 
distinta, o con nuevas posibilidades de- 
bido a la existencia de varios usuarios que 
comparten los recursos del sistema. 

El número máximo de usuarios que ad- 
mite el sistema operativo MP/M es de 
16; numerados, respectivamente, del 0 al 
15. Ello impone, obviamente, una serie de 
cargas sobre la memoria principal del sis- 
tema; toda vez que cada usuario recibe la 
asignación automática de una porción de 
la misma cuando se conecta al sistema. 

Es evidente, que el espacio total de me- 
moria ha de ser lo bastante grande para 
que los usuarios no se vean excesiva- 
mente limitados en el uso de programas 
de relativo tamaño, Por lo que respecta a 
las exigencias hardware, el sistema 
MP/M necesita un mínimo de 48 Kbytes 
de memoria RAM en el ordenador que lo 
soporta. Hay que tener en cuenta que sus 
posibilidades le permiten controlar hasta 
dieciséis unidades de disco asociadas al 
equipo. El espacio de memoria ocupado 
por el sistema operativo es variable; por 
un Jado depende de la propia versión del 
sistema operativo que se utilice, y por otro 
de la configuración física de terminales y 
periféricos. Acerca de este último condi- 
cionante, cabe precisar que hay una serie 
de informaciones, imprescindibles para el 
funcionamiento del sistema, que corres- 
ponden a cada usuario y a cada consola; 
informaciones que, por supuesto, requie- 



Distnhución de la memoria ventral del 
ordenador al ac tuar bajo el control del 
sistema operativo \fPi\f. 



ren un espacio de almacenamiento en la 
memoria central del ordenador. 

ESTRUCTURA DE LA MEMORIA 
PRIMARIA 



Al cargar el sistema operativo MP/M en la 
memoria primaria del ordenador, desde el 
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El área de interface canaliza la 
interacción entre los diversos 
usuarios y los módulos del 
sistema operativo MPfM. 



USUARIO 1 



USUARIO 2 



USUARIO 16 
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disco en el que se encuentra almacenado 
Y por efecto de un proceso de arranque en 
: és:e pasa a ocupar una determinada 
zona de ia memoria de uso exclusivo El 
resto de la memoria primaria queda desti- 
nada al almacenamiento de los programas 
propios de los distintos usuarios que ac- 
ceder al sistema. 

La ubicación en la memoria física del con- 
junto de módulos que constituyen ef 
= "A es muy similar a la propia del 
Z~ V aunque en algunos aspectos exis- 
:e- fiables diferencias; principalmente 
en el área de programas de usuario. Esta 
birria se distribuye internamente en una 
sene de particiones denominadas seg- 
mentos de memoria. 

Er la zona alta de la memoria se aloja el 
módulo XDOS (Extended Disk Operating 
System); aunque no necesariamente en la 
posición superior de dicha zona, ya que el 
MP/M permite declarar una serie de pro- 
gramas residentes en memoria, y por lo 
ianto r utilízables por todos los usuarios del 
sistema, sin necesidad de repetir su pre- 
sencia en la zona reservada a cada usua- 
rio. De producirse tal situación, la porción 
más alta de la memoria se destinaría a 
estos programas, y a partir de ellos queda- 
ría emplazado el módulo XDOS. Tras éste, 
y en dirección a la zona baja de la memo- 
ria, se encontraría el módulo BDOS (Basic 
Disk Operating System) y, a continuación, 
el módulo XIOS (Extended Input Output 
System). 

Hasta este nivel, la estructura es similar a 
fa que corresponde al sistema operativo 
CP/M, De inmediato aparece un área de 
memoria, propia del MP/M, cuyo objeto 
es permitir la interacción entre el usuario y 
el sistema operativo Esta se subdivide 
internamente en tres zonas: 



USERSYS.STK 
CONSOLEDAT 
SYSTEM.DAT 

La porción de memoria ocupada por 
USERSYS.STK es de tamaño variable, ya 
que depende del número de segmentos 
en los que se ha dividido el área de memo- 
ria destinada a usuarios. Exactamente son 
64 bytes de memoria los que se asignan a 
cada segmento, a utilizar como área de 
almacenamiento temporal para que los 
programas de usuario hagan sus llamadas 
al sistema operativo (CALL BDOS). 
El área destinada a CONSOLE.DAT tam- 
bién es de amplitud variable, dado que 
depende del número de consolas asocia- 
das a la CPU. Cada consola conectada 
requiere un total de 256 bytes; éstos me- 
morizan lo que se conoce por las siglas 
TMP (Terminal Message Process): pro- 
grama reentrante en memoria por medio 
del cual se transmiten Jos comandos intro- 
ducidos a través del terminal a las colas de 
órdenes. En esta misma zona se almace- 
nan un conjunto de indicadores que sirven 
para identificar la consola en las operacio- 
nes de entrada/salida. 
El área de memoria destinada a SYSTEM. 
DAT tiene una longitud dependiente del 
numero de segmentos en los que se di- 
vide la memoria destinada r-ú usuario. Por 
cada segmento, son necesarios 256 bytes 
en fa zona SYSTEM.DAT. En este espacio 
de memoria se almacena ia información 
necesaria para la reconfiguración dinámica 
del sistema dependiendo de las necesida- 
des de utilización en cada momento. 
El resto de la memoria, en su zona baja, 
queda disponible para los usuarios. Dada 
la naturaleza multiusuario del MP/M, lo 
habitual es que dicha sección de memoria 



esté ocupada simultáneamente por varios 
programas. Para favorecer su almacena- 
miento, la referida zona estará fraccionada 
en nuevas subdivisiones, hasta un má- 
ximo de ocho r denominadas segmentos 
de memoria. Su tamaño, definido durante 




Distribución de ta zona de memoria central 
coman a todos los usuarios de i sistema. 



la generación del sistema, es variable en- 
tre 0 y 64 Kbytes. 

La generación del sistema consiste en el 
ajuste de toda una serie de parámetros, 
de acuerdo con las necesidades del usua- 
rio, en orden a que la máquina opere de 
forma adecuada y sin emplear recursos 
innecesariamente. Este es un proceso de 
total relevancia cuando el ordenador en 
cuestión no tiene una capacidad muy ele- 
vada; circunstancia muy común entre los 
microordenadores equipados con el sis- 
tema operativo MP/M. 
Cada uno de los segmentos destinados al 
usuario es comparable al área de TPA 
(Transient Program Area) del sistema ope- 
rativo CP/M. A su vez, cada segmento se 
divide en dos partes SPA (System Para- 
meter Area) y UCA (User Code Area). La 
porción SPA ocupa los primeros 256 bytes 
de cada uno de los segmentos y contiene, 
como su propio nombre indica, determi- 
nados parámetros del sistema. En ocasio- 
nes, recibe el nombre de "página base del 
sistema", ya que en el sistema MP/M, al 
igual que sucede en el CP/M, el tamaño 
de la página de memoria es de 256 bytes. 
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El resto de! espacio de memoria propio de 
cada segmento constituye el área UCA, 
Cuando un programa es cargado en me- 
moria, su código objeto se carga al princi- 
pio de! área UCA; la operación de carga \a 
realiza el intérprete de comandos CLI 



(Command Une Interprete^ quien, ade- 
más, es e! encargado de gestionar la co- 
municación entre las colas y el sistema 
operativo. 

A raíz de lo descrito, queda patente que la 
zona de memoria ocupada por los archi- 



vos propios del sistema operativo, es 
compartida por todos los usuarios; el ac- 
ceso a la misma se gestiona a través del 
área de "interface" o de interacción con el 
usuario. 

El hecho de que no existan repeticiones 



Acceso concurrente a ficheros 



Al entrar en un entorno mu Iti usuario, la 
gestión de los ficheros se complica: 
varios usuarios pueden intentar un acceso 
simultáneo, dando origen a conflictos en 
cuanto a la veracidad y seguridad de la 
información del sistema. 
Un caso muy frecuente es el que se 
presenta cuando varios usuarios intentan 
actualizar un fichero y se mandan dos 
órdenes de actualización, casi 
simultáneamente, hacia el mismo registro. 
En esta situación, actualizaría el registro 
en primer lugar del usuario que ejecutó la 
orden de modificar el registra con mayor 
antelación. No obstante, puede ocurrir que 
antes de concluir la modificación dirigida 
por el primer usuario, empiece a ser 
activa la del segundo. Eflo conduce a una 
situación conflictiva, ya que se están 
intentando dos operaciones de 
modificación simultáneas sobre un mismo 
registro. 

Al actuar sobre un fichero, ya sea de tipo 
secuencial o de acceso aleatorio (acceso 
directo), el sistema elude los posibles 
inconvenientes con el uso combinado de 
diversos modos de apertura de ficheros y 
con ef bloqueo de los registros a 
modificar 

Cuando se procede a la apertura de un 
fichero se pueden especificar tres modos 
de actuación: 

— Modo bloqueado. 

— Modo desbloqueado. 

— Modo de sólo lectura. 

Con apertura en modo bloqueado, un 
proceso sólo puede abrir un fichero si 
éste no estaba ya previamente abierto. 
Una vez que se ha realizado su apertura 
ningún otro proceso puede acceder a 
dicho fichero hasta que el proceso inicial 
proceda a cerrarlo. Los ficheros abiertos 
de esta forma pueden ser objeto de 
lectura y escritura, a no ser que, además, 
se haya indicado que el fichero es 
accesible sólo para lectura, en cuyo caso 
ésta será la única operación realizable. 
La apertura en modo desbloqueado 
permite abrir un fichero aunque otro 
proceso lo haya hecho con anterioridad; 
en tal caso, todos los procesos que abran 
el fichero pueden acometer operaciones 
de lectura y escritura. 



En modo de soto lectura, ef intento de 
apertura de un fichero por parte de un 
proceso, sólo resultará eficaz si el fichero 
no estaba ya abierto pe otro proceso; o 
si, aún estando abierto, tal operación se 
ha realizado también en modo de sólo 
lectura. Como su nombre indica, en esta 
situación sólo se permitirá la lectura del 
fichero, resultando prohibida la 
modificación de cualquier parte 
del mismo. 

A raíz de los párrafos anteriores, se 
observa que aún no se ha resuelto el 
problema de la concurrencia sobre un 
registro, aunque se han puesto trabas 
para que no todos fos procesos tengan la 
capacidad de modificar un fichero, En 



consecuencia, es necesario bloquear los 
registros, además de los ficheros, para 
evitar posibles contingencias. 
El bloqueo de registros sólo puede 
realizarse sobre ficheros abiertos en modo 
bloqueado o de sólo lectura. Tal medida 
hace posible que al ejecutar una 
operación que modifique el fichero, el 
proceso sea dueño exclusivo def registro, 
bloqueando el acceso de los demás 
procesos; una vez concluida la 
transacción pendiente, el registro quedará 
liberado. 

Estas dos herramientas son utilizadas por 
el módulo BDOS del sistema operativo 
para gestionar las entradas y salidas 
concurrentes a ficheros. 




MODO DE 
ACCESO AL 
REGISTRO 



MODO DE 
APERTURA 
DEL FICHERO 




MODO DE 
ACCESO AL 
FICHERO 



La puesta en práctica de las distintas técnicas de acceso a ficheros y a registros* 
permiten la explotación concurre me de los ficheros del MPjM. 
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E. \ÍP¡M es un sistema operativo con 
capacidad para trabajar en régimen 
n ::t' t !i usuario y muí t ¡tarea* 

ze información o duplicidades en el alma- 
:-r~ a miento de los archivos del sistema 
::erativo favorece la dedicación de un 
mayor espacio de memoria a los usuarios. 



ESTRUCTURA DEL DISCO 



En un párrafo precedente se ha señalado 
que antes de la carga del sistema opera- 
tivo MP/M, es necesario proceder a la 
definición de una serie de parámetros ne- 
cesarios para su eficaz operación; pará- 
metros que se concretan, por ejemplo, en 
el número y tamaño de los segmentos en 
los que es preciso dividir el área de me- 
moria destinada a los usuarios. La genera- 
ción puede realizarse empleando determi- 
nados comandos, almacenados en la me- 
moria permanente (ROM), o bien por me- 
dio de un programa especial que se carga 
en la memoria con este fin exclusivo. 
Af igual que ocurre con el sistema opera- 
tivo CP/M, el MP/M ocupa las dos prime- 
ras pistas del disco sobre e! que se en- 
cuentra almacenado. Sin embargo, dado 
que es bastante más voluminoso, su pre- 
sencia se extiende a otras pistas def 
disco, Más exactamente, el MP/M se al- 
macena adoptando la forma de un fichero 
denominado "MPM.SYS"; éste consti- 
tuye la imagen del sistema operativo 
MP/M en memoria primaría. Las dos pis- 
tas reservadas, la 0 y la 1, se encuentran 
ocupadas por el cargador del sistema ope- 
rativo. El cargador, a su vez, se encuentra 
dividido en dos fragmentos o módulos, 



PISTA 


SECTOR 


MODULO 


00 


01 


BOOT 


00 


02 








mpmldr' 


00 


25 




00 


26 








LDRBIOS 


01 


26 





[ 



Distribución de las pistas del disco 
reservadas ai sistema operativo MPjM. 



denominados, respectivamente, MP- 
MLDR y LDRBIOS. Ambos fragmentos se 
comportan como programas independien- 
tes, organizando la carga en memoria de 
los módulos constitutivos del MP/M y or- 
ganizando los datos del área de ,J inter- 
face" usuario-sistema. El MPMLDR utiliza 
datos que son generados previamente 
por el módulo LDRBIOS. Estos programas 
son activados por el módulo "bootstrap", 
localizado en la pista cero sector 1 del 
disco. 

El módulo LDRBIOS es el cargador que 
depende del entorno físico de la máquina; 
esto es, del número y tipo de los periféri- 



cos conectados y de la interrelación entre 
dispositivos físicos y lógicos. Sus primiti- 
vos, situados en posiciones sumamente 
determinadas, son empleados por el mó- 
dulo de carga MPMLDR. Su complemen- 
tario, el módulo MPMLDR r constituye el 
cargador lógico del sistema operativo 
MP/M. Es independiente del entorno fí- 
sico, ya que su misión se reduce a tomar 
el fichero MPM.SYS y trasladarlo a la 
memoria primaria con la ayuda del módulo 
de carga LDRBIOS; por supuesto, tal ope- 
ración la realiza adaptando la estructura 
del fichero a la que ha de tomar el sistema 
operativo en la memoria. 
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Visicalc (2) 

Funciones para el cálculo de los elementos 
de la hoja electrónica 



ras el estudio de los principa- 

Ules comandos que ofrece el 
VISICALC para gestionar la 
hoja electrónica, quedan por 
analizar las funciones cuyo cometido es 
definir las fórmulas de cálculo. A pesar de 
la gran importancia que adquieren los co- 
mandos, ya que de ellos depende la co- 
modidad del trabajo del usuario en la pan- 
talla, tal vez sea aún superior la relevancia 
de las funciones; éstas constituyen el ins- 
trumento apropiado para el cálculo auto- 
mático de los elementos de la hoja elec- 
trónica. 



FUNCIONES DEL VISICALC 



El símbolo reservado para identificar a las 
funciones VISICALC es "@", Ello per- 
mite, tanto al usuario como al propio pro- 
grama, diferenciar cómodamente el con- 
tenido de un elemento; si no va precedido 
por ningún símbolo especial, se tratará de 
un dato numérico o alfabético; en caso 
contrario, éste sera un comando si co- 
mienza por el símbolo "/", o una función 
si es rr @ " el símbolo que lo precede, 
A continuación se describen las principa- 
les funciones manejadas por el VISICALC, 
detallando, en cada caso r los posibles ar- 
gumentos y su significado. 



FUNCIONES FINANCIERAS 



Uno de los principales objetivos de las 
hojas electrónicas es facilitar el trabajo de 



FUNCIONES DEL VISICALC ) 



Financieras 



FACILITAN LA 
CREACION DE 
HOJAS 

ELECTRONICAS 
DE TIPO 
ECONOMICO Y 
FINANCIERO 



LOGICAS 

(100110001 íoonocoini 



PRODUCEN 

RESULTADOS DEL TIPO 
VERDAOERO O BALSO 



ESPECIALES 



UTILES PARA 
GESTIONAR ERRORES 
Y DISPONIBILIDADES 



MATEMATICAS 




PERMITEN EL 
EMPLEO DE LAS 
FUNCIONES 
MATEMATICAS 
CONVENCIONALES 



Las funciones que brinda ta hoja electrónica 
VISICALC son catalogahíes en c nafro 
g rapos ge n ericas : financieras , / ógica s , 
especiales v matemáticas. Algunas funciones 
pueden adscribirse a dos grupos; tal es el 
caso de la función "máximo', encuadra ble 
comí) función matemática o financiera. 



ejecutivos comerciales, economistas y fi- 
nancieros. Las funciones agrupadas en 
este epígrafe resultan especialmente ade- 
cuadas para este cometido. 



\ 

COMANDO 
VISICALC 



□ 



FUNCION 

VISICALC 
/ 



La distinción entre comando y fnnción 
VISICALC corre a cargo del símbolo 
identi fiador que precede a cada elemento. 



A VER AGE 

Sirve para calcular la media de un conjunto 
de valores contenidos en elementos de !a 
matriz. El máximo número de elementos 
que se pueden incluir en el argumento de 
esta función se eleva a 256. Su formato 
es: 

@ AVERAGE (lista de elementos) 
COUNT 

Se utiliza para contar el número de ele- 
mentos de la lista que constituye su argu- 
mento. El formato para invocar a la refe- 
rida función es: 

@ COUNT (lista de elementos). 
NPV 

Aun encabezando el grupo de funciones 
financieras, las dos funciones anteriores 
resultan útiles para otros cálculos de tipo 
general; en cambio., la función NPV es 
típicamente financiera. Como argumento, 
debe contar con una expresión o un valor 
concreto (P), y una porción de una fila o 
columna de ia matriz; este segundo argu- 
mento se especifica medíante la coorde- 
nada inicial, la final y un valor de 'paso" 
para llegar de una a otra. 
A partir de estos argumentos, la función 
NPV devuelve el valor neto actual del 
"cash flow" de los elementos indicados, 
descontando el porcentaje P. El formato 
de esta función es: 

@ NPV (porcentaje de descuento, parte 
de una línea), 

L0OKUP 

Utiliza como argumento una expresión o 
valor concreto designado por X H y una 
zona delimitada de una fila o columna. Su 
actividad consiste en extraer el máximo 
valor de la serie de elementos aportados 
que sea inferior a X. Por lo demás, alma- 
cena ese valor en la posición situada a la 
derecha y debajo de la línea de entrada. 
Su formato de llamada es: 
@ LOOKUP (tope de búsqueda, parte de 
una línea). 
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CHOOSE 

Sirve para localizar el n-ésimo elemento 

de valores de entrada. Para ello, utiliza 

como parámetros el cardinal buscado y 

una lista cualquiera de elementos de la 

matriz. Su formato coincide con; 

@ CHOOSE (número de orden, lista de 

elementos). 

MAX 

Pfefmne localizar el máximo valor dentro 
^ conjunto de elementos de entrada. 
5 ü _^ co argumento se reduce a la lista de 
e amentos entre los que se debe localizar 
sí valor máximo; de ahí que su formato 
sea: 

@ MAX (lista de elementos). 
MIN 

Función análoga a la anterior, aunque loca- 
lizando esta vez el mínimo valor que apa- 
rece entre los elementos de entrada. Su 
formato es: 

@ MIN (lista de elementos). 
SUM 

Calcula el sumatorio de los valores conte- 
nidos en la lista de elementos que consti- 
tuye su único argumento. Para invocar a 
esta función hay que recurrir al siguiente 
formato: 

@ SUM (lista de elementos) 



FUNCIONES LOGICAS 



Una característica común a todas las fun- 
ciones lógicas que se detallan a continua- 
ción, es que tanto los parámetros de en- 
trada como el resultado, sólo admiten ele- 
mentos cuyos valores sean "verdadero" o 
"falso". 

AND 

La función lógica AND (Y), produce como 
resultado el valor "verdadero" si y sófo si 
todos sus argumentos de entrada son 
"verdaderos". Los parámetros de entrada 
para esta función pueden ser valores lógi- 
cos {"verdadero" o "falso") , o bien expre- 
siones conformadas con valores lógicos. 
El formato de llamada es: 
@ AND (lista de elementos lógicos). 
FALSE 

En este caso se trata de una función cons- 
tante que produce siempre como resul- 
tado el valor "falso". Por lo tanto, cabe 



afirmar que la función FALSE está exenta 
de parámetros de entrada: 
@ FALSE. 

IF 

Aun siendo de tipo lógico, la función IF 
admite como parámetros de entrada valo- 
res numéricos o literales; ello constituye 
una excepción dentro de las funciones ló- 
gicas. Como argumento de entrada ad- 
mite una expresión de cualquier tipo (por 
ejemplo, elemento 1-B<5), y dos valores 
cualquiera (por ejemplo, X e Y), El resul- 
tado producido por la función será X en el 



ELEMENTOS 



caso de que la expresión sea verdadera, y 
coincidirá con Y cuando la expresión sea 
falsa La forma de llamar a esta fun- 
ción es; 

@ IF (expresión, pareja de valores). 
ISERROR 

Esta función admite a un elemento de la 
hoja electrónica como único argumento. 
Si el valor de dicho elemento es 
"ERROR", el resultado producido por la 
función será verdadero; en el caso contra- 
rio, esto es, si el elemento adopta cual- 
quier valor distinto de "ERROR", el resul- 



tado será falso. Su formato coincide con; 
@ ISERROR (elemento). 

ISNA 

La finalidad de esta función es semejante 
a Ja anterior; si bien el criterio para produ- 
cir el resultado será "NA" en vez de 
"ERROR", Por lo tanto, el resultado de la 
función será verdadero sí el valor de su 
único argumento es "NA" y será falso si 
el valor del argumento es distinto de 
"NA": 

® ISNA (elemento). 



J 



NOT 

La función lógica NOT (NO) devuelve un 
resultado lógico opuesto al de su único 
argumento de entrada. En efecto, si el 
argumento tiene como valor verdadero, el 
resultado producido por la función NOT 
será falso, mientras que si el valor del 
argumento es falso, ei resultado produ- 
cido será verdadero. El formato de lla- 
mada es el siguiente: 
@ NOT (elemento). 

OR 

Corresponde a la función de suma lógica. 
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De ahí que para producir un resultado ver- 
dadero, sea suficiente con que uno solo 
de tos elementos lógicos de entrada sea 
verdadero, con independencia de los valo- 
res que puedan tomar los restantes argu- 
mentos: 

@ OR (lista de elementos lógicos). 
TRUE 

De nuevo se trata de una función cons- 
tante. No precisa ningún argumento de 
entrada, ya que, invariablemente, produce 
como resultado el valor lógico verdadero. 
El formato adecuado es: 
@ TRUE. 



FUNCIONES ESPECIALES 



Dos de las funciones lógicas descritas te- 
nían encomendada la misión de compro- 
bar si el contenido de un elemento era 
"ERROR" o JJ NA" (el significado de 
''ERROR" es obvio y el de "NA" es "no 
disponible", o "not avaiiable" en inglés). 
El VISICALC ofrece dos funciones espe- 
ciales para conseguir que algún elemento 
de la hoja llegue a contener alguno de los 
referidos valores. 




Actuación de las funciones lógicas 
AND y OR. 

ERROR 

Dependiendo de la entrada producida, 



Teoría de funciones (I) 



Para manejar los datos numéricos en una 
hoja electrónica, es imprescindible utilizar 
fórmulas de cálculo que permitan obtener 
el valor de un elemento en función de 
otros elementos de la matriz. En 
definitiva, hay que recurrir a lo que en las 
Ciencias Matemáticas se denomina 
función. 

En breve síntesis, una función no es más 
que una expresión que permite calcular el 
valor ignorado de una o más variables, a 
partir de los valores conocidos de otras 
variables distintas a las iniciales. 
Atendiendo al número dé 
variables/incógnita, o variables 
desconocidas que se evalúan por medio 
de la expresión, es posible clasificar a las 
funciones de la siguiente forma: 

— Funciones simples. Son las que 
únicamente resuelven el valor de una 
variable. 

— Funciones de dos valores. Resuelven 
el valor de dos variables o incógnitas. 

— Funciones de tres valores. Resuelven 
el valor de tres variables o incógnitas 

En las hojas electrónicas de cálculo se 
utilizan únicamente funciones simples, va 
que tan sólo se pretende obtener el valor 
de un único elemento. 
Otra posible clasificación dentro de las 
funciones, es la que se obtiene sin más 
que contar el número de variables 
conocidas que intervienen en la 
expresión. En este sentido cabe hablar 
de: 

— Funciones de una variable. Son Jas que 
sólo utilizan una variable dentro de la 
expresión de cálculo. 

— Funciones de dos variables. Utilizan 
dos variables en la expresión. 

— Funciones de tres variables. Utilizan 
tres variables en la expresión. 

En las fórmulas de cálculo que se emplean 
en las hojas electrónicas, se pueden 



utilizar funciones de distinto número de 
variables. Por ejemplo, si en el elemento 
localizado en la fila 7 y columna 3 de la 
matriz, se desea obtener el valor 
resultante de multiplicar el elemento de ta 
fila 7 y columna 1 por la 
constante 1 00, y dividir el resultado por el 
elemento de la fila 7 y columna 2 — elk> 



equivale a calcular en la posición 7,3 el 
porcentaje que representa la posición 7,1 
sobre la posición 7,2 — , se utilizará una 
función simple de dos variables. Su 
expresión coincidirá con la siguiente; 



POSICION 7,3- 



POSICION 7,1x100 
POSICION 7,2 



£ 



FUNCION 



VARIABLES 
DESCONOCIDAS 



1 



EXPRESION 


DE 


VARIABLES 


CONOCIDAS 



7 



EJEMPLOS 



FUNCION SIMPLE DE 
UNA VARIABLE 
2 

Y = 3+X 



FUNCION SIMPLE DE 
DOS VARIABLES 

Y - X + 2.Z 



0 

0 



nz 



FUNCION DE DOS VMORES 
Y TRES VARIABLES 

J Y=X+Z 
Y = 2.X + T 



t 



J VALORES (INCOGNITAS) 
VARIABLES 



Definición elemental del concepto de función 
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Aplicaciones 



/ n 

/ 2 f~ 

1 • / 90° 
180 t ^ 


9?^\ 

n \ 

90 \ \.\ 
) 1 0 


\ V \ 90 ' 

V n 
\ 2 

\>^270 


M-y 36 °) 

n / 

2 / 



/^ro wií'í//} un ángulo en radianes, hay que 
considerar que ta circ unferencia total de 360 
grados tiene 2 radianes* En consecuencia, 
cada fracción de 90 grados coincidirá con 
¡2 radianes ( -número Pl). 



ABS 

Extrae el valor absoluto de un elemento 
numérico de la hoja electrónica, prescin- 
diendo de su signo. Ello significa que el 
resultado coincidirá con la expresión posi- 
tiva del valor que figure en el argumento 
de entrada. 

@ ABS (elemento numérico}. 




Una 

característica de 
las junciones 
SfN (seno) y 
COS (coseno) es 
que su valor está 
siempre 
comprendido 
entre los valores 
-i v /. 



esta función hace que todas las expresio- 
nes referentes al valor se convierten en 
"ERROR". Esta función sin argumento se 
invoca sencillamente con: 
% ERROR. 

NA 

Función análoga a la anterior, con la salve- 
dad de que, en este caso, el valor se con- 
vierte en "A/A" (no disponible). El formato 
de llamada es: 
@ NA. 

FUNCIONES MATEMATICAS 



Este último grupo integra a las funciones 
"por excelencia": las especializadas en 
definir relaciones matemáticas entre los 
elementos de la hoja electrónica. 



SIN 

Función seno. Sirve para calcular el valor 
del seno del argumento de entrada. Este 
debe ser un elemento numérico repre- 
sentativo de un ángulo expresado en ra- 
dianes. Su formato de llamada es: 
@ SIN (elemento numérico). 

eos 

Función coseno. Calcula el coseno trigo- 
nométrico del valor de entrada, conside- 
rado éste como un ángufo en radianes: 
@ COS (elemento numérico). 

TAN 

Función tangente. Determina la tangente 
del ángulo cuyo valor en radianes consti- 
tuye el argumento de entrada: 
@ TAN (elemento numérico). 

ASIN 

Función arcoseno. Calcula el valor en ra- 
dianes del ángulo cuyo seno coincide con 
el valor numérico del argumento de en- 



trada. Su formato de llamada es: 
@ ASIN (elemento numérico). 

ACOS 

Función arcocoseno Determina el valor 
en radianes del ángulo cuyo coseno coin- 
cide con el dato reflejado en el argu- 
mento: 

@ ACOS (elemento numérico). 
ATAN 

Función arcotangente. Responde con el 
ángulo en radianes cuya tangente es igual 
al valor numérico incluido en el argumento 
de la función: 

@ ATAN (elemento numérico). 
LOG 10 

Logaritmo decimal. Función de un único 
argumento que produce como resultado 
el logaritmo decimal de dicho argumento. 
El resultado es tal que si se eleva la base 
10 af valor producido por la función, se 
obtendrá el número que aporta el argu- 
mento. El formato para invocarla es: 
@ LOG 10 (elemento numérico). 

LN 

Logaritmo nepenano. Calcula el logaritmo 
neperiano o natural (cuya base es el nú- 
mero "e"=2718...( del valor expresado 
en el argumento: 
@ LN (elemento numérico), 

EXP 

Función exponencial. Calcula el valor del 
número "e" elevado al argumento de en- 
trada; su formato es el siguiente: 
@ EXP (elemento numérico). 

INT 

Parte entera. Esta función se comple- 
menta con un único argumento, coinci- 
dente con cualquier elemento numérico 
de la hoja electrónica. Entrega como re- 
sultado la parte entera de dicho argu- 
mento; para ello elimina del mismo los 
decimales que pueda incorporar: 
@ INT (elemento numérico). 

SOflT 

Raíz cuadrada. El resultado producido por 
esta función es la raíz cuadrada del valor 
de su único argumento numérico de en- 
trada. Para invocarla hay que especificar: 
@ SORT (elemento numérico). 

Pl 

Esta es una función constante que no re- 
quiere argumento; responde dando el va- 
los del número Pl: 3 r 141 5926536. Su for- 
mulación se reduce a: 
@ Pl. 



220 



goggggiiggg 



